기본 콘텐츠로 건너뛰기

개발 공부 - Ping 테스트 시 차단 되어있는 경우 확인 방법

 ping 테스트 시에 ping 이 안 가는 경우에는 ICMP 차단이 되어 있는 것이다. ping이 네트워크 장비 간 연결 상태를 확인하기 위해 사용하는데, ICMP echo 요청을 보내고, echo의 응답을 받는 방식으로 동작한다. 일단 ping이 안 가더라도 정상적으로 브라우저에서 인터넷이 될 수도 있는데, 이유는 웹 브라우저가 http/https 프로토콜을 사용해서 웹 서버와 통신하기 때문이다. 이것이 TCP 위에서 동작하므로 ICMP와는 별도로 동작한다. ICMP가 주로 네트워크 진단이나 오류 보고 시에 사용하기 때문에 보통 ping 테스트를 하여 네트워크 경로 문제 진단을 하거나, 패킷 손실량을 확인하는 데 사용하지만, 실제 데이터 전송과는 차이가 있다. 그리고 ICMP 차단을 하면 방화벽이나 특정 네트워크 장비에서 설정을 하는데, 보안상 이유로 네트워크 특정 부분에서만 작동할 수도 있고, 나머지 다른 경로를 통해서 데이터를 전송하게 만들 수도 있다. 대부분 TCP/IP를 통해 직접 통신을 하므로 ICMP 차단과 관계없이 데이터 송수신이 가능하다. 따라서 ICMP를 차단하면 네트워크 진단 도구에서 오류가 날 수는 있지만, 애플리케이션 단에서는 오류가 안 날 수도 있다. 그런데 시스템 관리자 등에게 요청하기 전에 정상적으로 네트워크 통신이 되는 것을 확인하기 위해서는 아래와 같은 명령어가 있다. 일단 윈도우에서는 tracert를 통해서 패킷 이동을 볼 수 있는데, tracert도 막힐 수 있다. 그러면 nslookup 을 통해서 DNS 설정이 올바른지 일차적으로 확인할 수 있다. nslookup 명령어를 쳐서 DNS 서버에 문의하여 도메인 이름을 IP 주소로 변환하거나, 그 반대로 변환을 할 수 있다. netstat을 통해서 -an 옵션을 넣어서 현재 모든 활성 연결과 포트를 볼 수 있는데, 이를 통해서 네트워크 트래픽을 지켜볼 수 있다. 그리고 미리 telnet 클라이언트를 활성화해 놓고 나서 telnet을 통해서 IP와 port를 확인 할 수도 있다
최근 글

개발 공부 - Oracle Table Comment Copy (테이블 컬럼 주석 복사)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 SELECT       ATC.COLUMN_NAME,     ACC.COMMENTS FROM       ALL_TAB_COLUMNS ATC LEFT JOIN      ALL_COL_COMMENTS ACC  ON       ATC.TABLE_NAME  =  ACC.TABLE_NAME      AND ATC.COLUMN_NAME  =  ACC.COLUMN_NAME WHERE       ATC.TABLE_NAME  =   '테이블명' ORDER   BY       ATC.TABLE_NAME,      ATC.COLUMN_ID; cs DDL로 Comment가 복사가 안 되어서 뽑아서 썼다. 출처의 VIEW 권한은 있어서 권한은 빼버렸다. 출처 : https://aurum.tistory.com/16

개발 공부 - wsl 로 리눅스에 설치하기

 리눅스 마스터 취득을 위해서 wsl로 설치 해 보았다. 1. PowerShell을 관리자 권한으로 실행한다. 2. Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux 을 실행한 뒤에 Y를 눌러서 재부팅한다. 3. https://www.microsoft.com/store/productId/9PDXGNCFSCZV?ocid=pdpshare 에 가서 다운 받아서 사용하면 된다.  4. 설치가 완료되면 그냥 사용하면 된다. 윈도우랑 공유하는 mount 폴더는 /mnt 에 위치한다. 5. gui 도 사용하고 싶으면 아래와 같이 설치하면 되는데 windows 11 이상이라던지 조건이 많이 있다.  sudo apt-get update sudo apt-get upgrade sudo apt-get install ubuntu-desktop (오래 걸린다.) sudo apt-get install indicator-appmenu-tools sudo apt-get install indicator-session sudo apt-get install indicator-datetime sudo apt-get install indicator-applet-complete sudo apt-get install lightdm sudo service lightdm start sudo apt install wsl sudo apt update sudo apt install gnome-text-editor -y 회사에서는 Microsoft Store가 막혀서 복잡하게 설치했는데, 기본적으로는 저렇게 하면 된다. . 복잡하게 설치하는 법은 참조 URL의 2~5를 참조하면 된다. 참조 URL 1. https://zerobig-k8s.tistory.com/40 2. https://cloudpang.tistory.com/3 3. https://8ugust-dev.tistory.com/3 4. https://le

개발 공부 - Whale 브라우저에서 이미지 표시 하지 않기

whale://settings/content/images?search=%EC%9D%B4%EB%AF%B8%EC%A7%80 개인정보 보호 → 사이트 설정  → [콘텐츠] 이미지  사이트 전체 차단을 할 수도 있고, 내가 한 것처럼 [*.]blog.naver.com 만 차단 해도 된다.

개발 공부 - Whale 웹 콘텐츠 다크 모드

웹 콘텐츠 다크 모드 사용/종료 [Alt + Shift + D] 위 브라우저 명령어가 기본 whale 다크 모드 설정 명령어이다. 그런데, 이 옵션을 안 바꿔주면 모든 사이트에 적용 모드가 기본이다. 따라서 부분적으로만 사용하고 싶으면 [현재 사이트에 적용] 버튼을 눌러 둬야 한다. 다크 모드 예약을 하지 않고 원래부터 윈도우에 따라서 설치가 됬던 것 같지만 정확히 기억이 안 나고, 블로그가 너무 쨍해서 다크 모드로 바꿔 주었다. 이거 단축키 눌러도 단축키가 안 먹는다고 생각한다면 url 주소창에서 누르면 바뀐다!

개발 공부 - 마이크로서비스 통신에서의 동기와 비동기의 차이

MSA에서 서비스 간 통신은 동기 / 비동기로 나눌 수 있다. 1. 동기 통신 (Synchronous Communication) (1) 정의 클라이언트가 요청을 보내고 서버로부터 응답을 받을 때까지 기다리는 방식이다. 일반적으로 HTTP/REST, gRPC 등이 동기 통신에 사용된다. (2) 특징 응답 : 즉각적이다. 클라이언트는 서버로부터 즉각적인 응답을 받는다. 복잡성 : 단순하다. 구현이 비교적 단순하며, 요청-응답 패턴이 명확하 장애문제 : 서버가 응답을 주지 않으면 클라이언트는 타임아웃이 발생할 수 있다. 결합도 : 서비스 간의 결합도가 높아질 수 있다. 하나의 서비스가 느려지거나 다운되면 전체 시스템에 영향을 미칠 수 있다. (3) 사용 사례 실시간 데이터 조회 사용자 인증 및 권한 부여 단순한 CRUD 작업 (4) 요약 [동기] 응답 시간 : 즉각적 구현 복잡도 : 낮음 결합도 : 높음 확장성 : 낮음 내결함성 : 낮음 사용 사례 : 실시간 조회, 인증 2. 비동기 통신 (Asynchronous Communication) (1) 정의 클라이언트가 요청을 보내고 즉시 다음 작업을 수행하며, 서버의 응답은 나중에 비동기적으로 처리되는 방식이다. 메시지 큐(Kafka, RabbitMQ), 이벤트 스트리밍, WebSocket 등이 비동기 통신에 사용된다. (2) 특징 응답 : 비즉각적이다. 클라이언트는 서버의 응답을 기다리지 않고 다른 작업을 계속할 수 있다. 복잡성 : 구현이 비교적 복잡하며, 메시지 전달 보장, 순서 보장 등의 추가적인 고려사항이 필요하다. 장애문제 : 하나의 서비스가 다운되더라도 전체 시스템에 미치는 영향이 적다. 결합도 : 서비스 간의 결합도가 낮아져 시스템의 확장성이 높아진다. (3) 사용 사례 주문 처리 시스템 이메일 전송 로그 수집 및 분석 비동기 이벤트 처리 (4) 요약 [비동기] 응답 시간 : 지연될 수 있음 구현 복잡도 : 높음 결합도

개발 공부 - 윈도우에서 프로그램 창 최상단 고정 (deskpins)

https://deskpins.softonic.kr/ 위 링크에서 다운 받을 수 있고, 이렇게 notepad 등 위에 올려놓고 싶은 창을 고정을 시킬 수 있다. blogger라서 파일 첨부가 귀찮기 때문에 홈페이지 링크만 걸어둔다. 작업 표시줄의 옵션에 들어가서 핀의 색상도 바꿀 수 있다. 출처 : 웹 서칭 하다가 댓글에서 발견했지만, 세부 사항은 아래에서 확인했다. https://verycrazy.tistory.com/48

개발 공부 - SECURE CRT Configuration 복원

회사에서 SecureCRT를 쓰는데, 설정 자체를 옮겨 받아야 할 일이 생겨서 기재한다. 기존에 사용하거나 인수인계 시에는 C:\Users\사용자\AppData\Roaming\VanDyke\Config에 있는 Config 파일을 옮겨서 사용하면 된다. 이미 라이선스 인증이 된 상태여야 정상 동작한다. 라이선스는 회사 것이라 정품을 사용하기는 하는데 이러한 것 도 있는 것 같다. 하지만 DBeaver 를 쓰는 트렌디한 나의 모습.

개발 공부 - 자주 쓰는 리눅스 명령어 공부

grep 정리를 하다가 3년 전에 쓰려다 만 글을 꺼내서 추가 기재한다. 이렇게 쌓인 숙제를 하나 씩 해결하면 언젠가 끝날 숙제! 어쨌든 아래와 같다. 0. grep: 파일에서 지정된 패턴을 검색합니다. 패턴에 해당하는 모든 라인을 표시한다. grep "패턴" 파일 명 grep 을 기본밖에 안 써서, 조금 더 잘 써보려고 상세 정리를 했다.

개발 공부 - LastPass (암호 관리 프로그램)

LastPass는 암호 관리 프로그램이다. 이 프로그램에 암호를 저장해 두면, 암호를 어렵게 만들어도 이 프로그램이 자동 완성을 해 준다. LastPass 서버에서 암호를 저장하는 것이 큰 문제이긴 한데, LastPass 서버 해킹 시 개인 정보가 전체 다 날아가기 때문이다!!!!!!! 그래서 크롬에 중요하지 않은 정보만 자동완성으로 저장해서 사용했는데, 회사에서는 크롬 정책 자체가 막혀 있기 때문에 local 테스트 시 귀찮아서 설치했다. 진짜 중요한 정보는 못 넣을 것 같지만 일단 편하게 살려고 깔았다. 이전 회사에서 부장님이 구글 스프레드시트로 비밀번호 복붙 하시는 걸 보고 너무 무서워서 조금 두려워하며 LastPass를 사용했는데, 알려드리니 전사 유료결제를 해 주셨었다. 그런 유료 정책은 좋은 회사였지만 이전 회사! 아무튼 잘 쓰고 있었는데 유료 결제를 안 하면 모든 단말기가 아닌 한 단말기 유형에서만 사용할 수 있다고 한다. 단말기라는 것은 PC나 mobile 중 하나만 되는 것이라고 한다. 아무튼 잘 쓰고 있으므로 기재해 보았다. 이것도 2023년 8월 2일에 제목만 써 두고 기재를 안 한 것이라서, 그냥 개념적인 정리를 하려고 했었나? 라고 생각하며 기재했다.