인기글
-
[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..
-
[C#, Winform]Form 종료 이벤트 설정 방법
C#에서 폼을 종료 하는 메서드는 아래와 같다. - FormClosing() - FormClosed() - Close() 위 이름에서 알 수 있듯이, 사용자가 폼의 x(종료) 버튼을 누르면, 아래 순으로 메서드가 호출된다. FormClosing() --> Close() --> FormClosed() 폼이 종료되는 시점에 뭔가를 수행하려면 FormClosing 이벤트를 사용하는 것이 권장 되며, FormClosing 이벤트시 동작을 구현 하기 위해서는 아래 절차를 수행하면 된다. 폼 종료 시, 아래와 같이 사용했던 인스턴트를 정리 할 수 있다. 아래와 같이 정리 하지 않으면, 간혹 백그라운드에서 동작 하고 있는 인스턴트를 볼 수 있다. private void Main_FormClosing(object se..
-
[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를 처음 사용하시나요? 새로운 개발 도구를 학습하는 것은 어려울 수 있습니다. 이 단계별..
-
[RabbitMQ] 다른 메시지 큐 간 차이 (MQTT, ZeroMQ, Kafka)
RabbitMQ AMQP 프로토콜을 구현해 놓은 프로그램 신뢰성, 안정성과 성능을 충족할 수 있도록 다양한 기능 제공 유연한 라우팅: Message Queue가 도착하기 전에 라우팅 되며 플러그인을 통해 더 복잡한 라우팅도 가능 클러스터링: 로컬 네트워크에 있는 여려 RabbitMQ 서버를 논리적으로 클러스터링 할 수 있고 논리적인 브로커도 가능 함. 오픈 소스로 상업적 지원이 가능 Kafka 대용량 실시간 로그 처리에 특화되어 설계된 메시징 시스템 기좀 범용 메시징 시스템 대비 TPS(Transaction Per Second)가 매우 우수함 특화된 시스템이기 때문에 범용 메시징 시스템에서 제공하는 다양한 기능들은 제공 되지 않음 AMQP 프로토콜이나 JMS API를 사용하지 않고 단순한 메시지 헤더를 ..
-
[SAE J1939] DM1 ( Diagnostic Message 1)
DM1(Diagnostic Message 1) - Active Diagnostics Trouble Code DM1은 PGN 65226(0xFECA)를 사용하며, 활성 DTC가 있거나 요청의 응답이 있는 경우에만 주기적으로 전송 된다. 활성화 된 DTC가 1개 이상일 경우, DM 1 메시지는 전송 프로토콜을 사용 하여 전송되며, 이 메시지의 전송 주기는 1초이다. 전송 프로토콜 장치에서 DM1 메시지를 보내기 위해서는 아래와 같은 전송 프로토콜을 사용한다. 처음 J1939 Transport Protocol BAM( Connection Management ) 메시지를 보내서 앞으로 보낼 DM1 메시지의 메시지 Size, Packet의 갯수, DM1의 PGN을 Receiving Node에게 알려 준다. 이후,..
-
[OCPP Charge Point #1] Steve와 Websocket 연결 테스트
mobilityhouse/ocpp 프로젝트 OCPP(Open Charge Point Protocol)와 관련된 Python 라이브러리르 제공하는 GitHub 프로젝트입니다. https://github.com/mobilityhouse/ocpp GitHub - mobilityhouse/ocpp: Python implementation of the Open Charge Point Protocol (OCPP). Python implementation of the Open Charge Point Protocol (OCPP). - GitHub - mobilityhouse/ocpp: Python implementation of the Open Charge Point Protocol (OCPP). github.com ..
-
[Python] serial module 사용 실패 시, 해결 방법
Serial Module 사용 실패 시, 해결 방법 Python에서 Serial Module을 사용하려고 하다 보면 아래와 같은 에러가 발생 할 수 있습니다. ImportError: No module named serial 위 경우에는 이미 설치되어 있는 Python 라이브러리에 시리얼 통신을 위한 라이브러리가 존재 하지 않아 발생한 문제 입니다.이를 해결하기 위해서는 아래 경로에서 pyserial을 설치하면 됩니다. https://pypi.python.org/pypi/pyserial
최근 작성된 글
-
리눅스 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..