인기글
-
[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" 각 컨테이너의 로그 끝부터 표시
-
[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..
-
[Python] serial module 사용 실패 시, 해결 방법
Serial Module 사용 실패 시, 해결 방법 Python에서 Serial Module을 사용하려고 하다 보면 아래와 같은 에러가 발생 할 수 있습니다. ImportError: No module named serial 위 경우에는 이미 설치되어 있는 Python 라이브러리에 시리얼 통신을 위한 라이브러리가 존재 하지 않아 발생한 문제 입니다.이를 해결하기 위해서는 아래 경로에서 pyserial을 설치하면 됩니다. https://pypi.python.org/pypi/pyserial
-
[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 ..
-
[FreeRTOS] Task에서 사용하고 있는 최대 Stack Size 확인 법
FreeRTOS 기반으로 어플리케이션을 개발 하다 보면, Task의 Stack Size 설정이 필요하며 이를 적절한 값으로 설정해야 할 필요가 있다. FreeRTOS에서 제공하고 있는, uxTaskGetStackHighWaterMark 함수를 이용하면, 동작하고 있는 Task에 얼마만큼 여유 Stack이 남아 있는지를 확인 할 수 있다. Returns Word 단위로 Stack Size가 Return 됨 예를 들어 32bit 머신에서 1은 4bytes의 stack size가 사용되지 않고 있다는 의미 Return되는 값이 0인 경우, Stack Overflow 발생( 사용 가능한 Stack이 남아 있지 않다는 의미 ) uxTaskGetStackHighWaterMark 기능을 사용하기 위해서는 아래 절차를..
-
[CAN] CAN Frame 구조
CAN Frame 구조 SOF(Start Of Frame) 데이터를 전송하고자 하는 노드는 SOF를 송신함으로서 메시지 전송을 시작한다. SOF는 1bit로 구성되어 있으며 이 신호에 의해 모든 노드는 싱크되어 수신 및 응답 준비가 되야 한다. ID(Identifier) Field CAN에서의 ID는 메시지를 식별하는데 사용된다. CAN 2.0A(Standard)는 11bit, CAN 2.0B(Extension)는 29bit로 구성되어 있다. Control Field Control Field는 6bit로 구성되어 있으며, 첫번째(IDE), 두번째(R0) bit는 Standard Type인지 Extenstion Type인지를 구분하는데 사용된다. 나머지 4bit는 DLC(Data Length Code)로 ..
-
[SAE J1939] DTC(Diagnostic Trouble Code)
진단 고장 코드(DTC, Diagnostic Trouble Code) 시스템에 발생한 결함 정보를 나타냄. 주로 현재 상태가 비정상적인 SPN을 나타냄 용어 정리 Suspect Parameter Number(SPN, 의심 파라미터 번호) 오류가 있는 SPN을 나타냄. 정의된 모든 SPN은 DTC에서 사용 할 수 있음 Failure Mode Identifier(FMI, 고장모드 식별자) 발생한 오류의 특성 및 유형을 나타냄 예) 값 범위 위반(초과 또는 미달), 센서 단락, 잘못된 업데이트 속도, 교정 오류 등. Occurrence Counter(OC, 발생 카운터) 각 SPN에 대한 오류 조건 발생 횟수를 계산하고, 오류가 종료된 경우에도 이를 저장하는 카운터 SPN Conversion Method(SP..
최근 작성된 글
-
리눅스 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..