인기글
-
[C#, Winform]Form 종료 이벤트 설정 방법
C#에서 폼을 종료 하는 메서드는 아래와 같다. - FormClosing() - FormClosed() - Close() 위 이름에서 알 수 있듯이, 사용자가 폼의 x(종료) 버튼을 누르면, 아래 순으로 메서드가 호출된다. FormClosing() --> Close() --> FormClosed() 폼이 종료되는 시점에 뭔가를 수행하려면 FormClosing 이벤트를 사용하는 것이 권장 되며, FormClosing 이벤트시 동작을 구현 하기 위해서는 아래 절차를 수행하면 된다. 폼 종료 시, 아래와 같이 사용했던 인스턴트를 정리 할 수 있다. 아래와 같이 정리 하지 않으면, 간혹 백그라운드에서 동작 하고 있는 인스턴트를 볼 수 있다. private void Main_FormClosing(object se..
-
[Windows] OpenSSH 서버 활성화 방법
Windows, OpenSSH 서버 활성화 1. 관리자 모드로 PowerShell 실행 2. OpenSSH.Server 설치 명령 - $ Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0 3. sshd 서비스 등록 - Start-Service sshd 4.부팅 시점에 자동으로 서비스를 실행하고 싶으면 Set-Service에 등록 - Set-Service -Name sshd -StartupType 'Automatic' 5. OpenSSH-Server에 대한 방화벽 규칙 확인 - 명령 : Get-NetFirewallRule -Name OpenSSH-Server-In-TCP - Enabled : True면 정상 5.1 만약 OpenSSH-Server..
-
[Docker-compose] 실행 중인 컨테이너 로그 확인 방법
실행 중인 모든 서비스의 로그를 확인 하는 방법 docker-compose logs -f -t 실행 중인 특정 컨테이너 로그 확인 하는 방법 docker-compose logs -t -f logs 옵션 설명 -no-color : 단색 출력을 생성 -f, -follow : 로그 출력을 따라감 -t, -timestamps : 타임 스탬프 표시 -tail = "all" 각 컨테이너의 로그 끝부터 표시
-
[Visual Studio] Visual Studio 설치 관리자 업데이트를 다운로드하지 못했습니다. 오류 해결 방법
Visual Studio Installer 사용 중 패키지 설치 및 업데이트를 하려고 하니 아래와 같이 오류가 발생 했다. 아래 링크 주소로 접속해서, Visual Studio 설치 파일 재 다운로드 후 다시 설치 한다. https://visualstudio.microsoft.com/ko/thank-you-downloading-visual-studio/?sku=Community&channel=Release&version=VS2022&source=VSLandingPage&cid=2030&passive=false Visual Studio를 다운로드해 주셔서 감사합니다. - Visual Studio Visual Studio를 처음 사용하시나요? 새로운 개발 도구를 학습하는 것은 어려울 수 있습니다. 이 단계별..
-
HTTP 기본 인증 ( Basic authentication )
기본 인증(Basic authentication)의 예 서버가 사용자에게 인증 요구를 원할 때, 서버는 401 Unauthorized 응답과 함께 WWW-Authenticate 헤더를 포함해서 클라이언트에게 전송한다. 이 정보에는 클라이언트가 어떻게 인증해야 할지 포함되어 있고, 위 예시에서는 Basic 인증을 요청 한다. 해당 메시지를 받은 클라이언트는 서버에게 인증 메시지를 보낼 수 있다. 위 그림에서는 서버가 Basic 인증을 요청 했기 때문에, 인토딩(BASE64)된 비밀번호와 그 외 인증 파라미터들을 Authorization 헤더에 담아서 메시지를 보낸다. 성공적으로 완료되면 서버는 정상적으로 200 OK 코드를 반환한다. 추가적인 인증 알고리즘에 대한 정보는 Authentication-Info..
-
[RabbitMQ] 다른 메시지 큐 간 차이 (MQTT, ZeroMQ, Kafka)
RabbitMQ AMQP 프로토콜을 구현해 놓은 프로그램 신뢰성, 안정성과 성능을 충족할 수 있도록 다양한 기능 제공 유연한 라우팅: Message Queue가 도착하기 전에 라우팅 되며 플러그인을 통해 더 복잡한 라우팅도 가능 클러스터링: 로컬 네트워크에 있는 여려 RabbitMQ 서버를 논리적으로 클러스터링 할 수 있고 논리적인 브로커도 가능 함. 오픈 소스로 상업적 지원이 가능 Kafka 대용량 실시간 로그 처리에 특화되어 설계된 메시징 시스템 기좀 범용 메시징 시스템 대비 TPS(Transaction Per Second)가 매우 우수함 특화된 시스템이기 때문에 범용 메시징 시스템에서 제공하는 다양한 기능들은 제공 되지 않음 AMQP 프로토콜이나 JMS API를 사용하지 않고 단순한 메시지 헤더를 ..
-
[Python] 상위 폴더 import 방법
아래와 같은 폴더 구조로 파일이 있을 때, WizFi360_MacScan.py에서 testScheduleFactory.py를 Import 하는 방법을 설명 한다. \---PythonTestCode +---testScheduleManager | | testScheduleFactory.py | \---unitTest WizFi360_MacScan.py sys.path는 파이썬 라이브러리들이 설치 되어 있는 디렉터리들을 보여 준다. 만약 파이썬 모듈이 위의 디렉터리에 들어 있다면 모듈이 저장된 디렉터리로 이동할 필요 없이 바로 불러서 사용 할 수 있다. 아래 코드를 이용하면, 현재 파일의 상위 폴더(PythonTestCode)를 sys.path에 등록한다. sys.path.append(os.path.dirna..
-
2024년 주목할 주요 스타트업과 사업 아이템 정리
2024년 기준 주목할 만한 주요 스타트업과 그들의 사업 아이템에 대해 정리 합니다. Tome 전 메타 임원들이 설립한 Tome은 비즈니스 중심의 스토리텔링 및 프레젠테이션 도구로, 생성 AI를 활용하고 있습니다. 2023년에 10백만 이상의 사용자를 확보하며 비즈니스 커뮤니티에서 인기를 얻고 있습니다 Calendly 온라인 일정 관리 플랫폼은 팬데믹 기간 동안 성장을 경험했으며, 현재 전 세계적으로 약 10백만 사용자를 서비스하고 있습니다. 2023년에는 수익이 크게 증가했습니다 Gumroad 주말 프로젝트로 시작된 Gumroad는 창작자들이 소비자에게 직접 제품을 판매할 수 있는 글로벌 마켓플레이스 및 웹 빌더 플랫폼로 발전했습니다. 2023년에 수익이 크게 성장했습니다 Vibrant Planet..
최근 작성된 글
-
리눅스 usb-serial latency 값 줄이기
JIG에서 UART 메시지를 이용하여 Target MCU의 펌웨어 업데이트 하는 기능이 있습니다. Target MCU에 펌웨어 업데이트 시간을 줄이기 위해 MCU에서 지원하는 최대 baud_rate로 설정하고 리눅스에 설정되어 있는 usb-serial 장치의 latency_timer 값을 1로 설정 하였다. usb-serial/devices/latency_timer란 usb-serial 장치에서 데이터 전송을 얼마나 자주 할 것인지를 결정하는 설정 입니다. 이 값은 USB 버스에서 장치가 데이터 패킷을 보내는 빈도를 조절 합니다. 예를 들어, 'latency_timer'가 낮은 값으로 설정되어 있다면, 시스템은 더 자주 데이터를 보내게 되어 실시간성이 좋아 지지만 전체 처리량은 감소 할 수 있습니다. 반..
-
[OCPP Gateway] TW_OCPP
TW_OCPP란 전기차 충전소 관리 시스템(EV Charging Station Management System, 이하 Central System)과 충전소(Charge Point)간의 통신을 중계하는 장치 입니다. OCPP는 전 세계적으로 널리 사용되는 개방형 프로토콜로, 다양한 제조업체의 충전소와 관리 시스템 간에 호환성을 제공 합니다. 용어 정리 Central System Charge Point를 관리하고, 사용자가 해당 Charge Point를 사용할 수 있는지 여부를 인증하는 정보를 가지고 있는 중앙 시스템(Central System) Charge Point Charge Point는 전기차를 충전할 수 있는 물리적 시스템이다. Charge Point는 하나 이상의 충전 커넥터를 가짐 CSMS(Ch..
-
[django] 마이그레이션 롤백 하는 방법
기존 데이터를 유지하면서 django migrate로 마이그레이션 문제를 해결하기 위한 방법을 정리 합니다. 마이그레이션이 충돌되거나 문제가 발생 했을 때, 아래와 같은 명령으로 롤백 할 수 있습니다. 특정 migration_name에 지정된 스키마 형태로 마이그레이션 수행 $ python manage.py migrate [app_name] [migration_name] 만약 모든 마이그레이션을 롤백 하려면 아래 명령 수행 $ python manage.py migrate [app_name] zero
-
라즈베리파이, 오렌지파이 SD 카드 깨짐 문제
제품 개발을 하던 중, 보드의 전원이 갑자기 차단하면 보드의 SD 카드의 파일이 깨지는 현상이 있었습니다. 아마 보드 입장에서 프로그램이 동작하면서 파일 시스템의 파일들을 Write 하는 도중에 전원이 차단되어 파일이 깨지는 것으로 보입니다. 해결 방법 임시 해결 방법일 수 있으나, 아래와 같이 fstab 파일에 sync 옵션을 추가 하는 방법이 있습니다. $ sudo vi /etc/fstab UUID=73379811-91e8-4483-8aff-7d4bc3cca9f6 / ext4 defaults,sync,noatime,commit=600,errors=remount-ro 0 1 UUID=5BC1-359C /boot vfat defaults 0 2 tmpfs /tmp tmpfs defaults,nosuid ..
-
[쿠버네티스] CPU 점유율 메모리 사용량 확인, HPA 설정
쿠버네티스에서 사용하는 POD들의 CPU 점유율과 메모리 사용량을 확인 하는 방법과 Autoscaling을 위한 HPA 설정 방법을 정리 하였습니다. POD CPU 점유율과 메모리 사용량 확인 현재 사용 중인 pod의 CPU 점유율과 메모리 사용량을 확인하는 명령은 아래와 같습니다. CPU의 100m는 0.1 core를 의미 합니다. 메모리의 116Mi는 116Mbytes를 의미 합니다. kubectl top pods -n C:\>kubectl top pods -n testx-dev NAME CPU(cores) MEMORY(bytes) tx-msa-device-service-dev-8496684c75-bzph2 208m 116Mi tx-msa-fe-backend-service-dev-666555767d-..
-
[쿠버네티스] Helm 차트의 Resource와 Autoscaling
쿠버네티스에 Deployment를 위한 설정 중 Resource와 Autoscaling에 대해 정리 합니다. Resources 파드에 할당할 CPU와 메모리 리소스의 최소, 최대 한계를 정의 파드가 사용 할 수 있는 리소스의 양을 제한하여, 리소스의 과도한 사용을 방지하고, 다른 파드와의 리소스 경쟁을 최소화 하는데 도움을 줌 Resources 설정 예제는 아래와 같습니다. resources: requests: memory: "64Mi" cpu: "250m" limits: memory: "128Mi" cpu: "500m" requests 파드가 시작될 때 요청하는 리소스의 양 이 값을 기반으로 쿠버네티스 스케줄러는 파드를 적절한 노드에 배치 limits 파드가 사용할 수 있는 리소스의 최대 한계 이 한계..
-
[pyinstaller] 바이러스, 트로이 목마 문제 해결
pyinstaller를 사용하여 패키징 할 때, 멀웨어로 인식되는 문제를 해결한 방법을 정리 하였습니다. 문제 pyinstaller를 사용하여 python 프로그램을 패키징 할 때 아래와 같은 에러가 발생 하고 Windows Depender에서는 트로이목마 파일이 있다면서 에러를 출력 하였다. File "c:\Workspace\venv_phoenixon\lib\site-packages\PyInstaller\building\build_main.py", line 1071, in main build(specfile, distpath, workpath, clean_build) File "c:\Workspace\venv_phoenixon\lib\site-packages\PyInstaller\building\bui..
-
[PySide2] TextEdit의 textChanged 이벤트를 받아 개행 문자 삭제
Example Code TextEdit에서 입력된 값이 변경될 때 마다 이벤트를 받아 개행문자가 있는지 확인하고 삭제하는 예제입니다. TextEdit에 수정된 문자열을 입력하면서도 이벤트가 발생 할 수 있기 때문에 아래와 같이 무한루프를 방지하기 위한 코드를 추가 하였습니다. from PySide2.QtWidgets import QApplication, QTextEdit, QVBoxLayout, QWidget class MyWidget(QWidget): def __init__(self): super().__init__() # 레이아웃 설정 self.layout = QVBoxLayout(self) # QTextEdit 위젯 생성 및 레이아웃에 추가 self.text_edit = QTextEdit() sel..