728x90

코드를 만들 필요가 있을때 왠만하면 Node.js 를 이용하는 편입니다. 아무래도 익숙하기도 하거니와 자유로운 자바스크립트의 DNA 가 살아 있기 때문에 "대략 이렇게 돌아갈까?" 하는 것들이 동작하기 때문입니다. 하지만 환경에 따라서 특정한 언어를 사용해야 하는 경우에는 그 환경에 맞출 수 밖에 없는 경우도 생깁니다.

 

근래에 회사에서 제공하는 함수형 플랫폼을 사용하려다보니 (AWS 의 람다와 무척 비슷합니다) Python 을 사용할 일이 조금 생기고 있습니다. 본격적으로 다뤄본 언어도 아니고 개발환경도 익숙하지 않아 시행착오가 많이 생기고 있습니다. 오늘 만난 문제는 Visual Studio Code 에서 Python 을 사용할 때 발생하는 Unresolved Import Error 에 대한 이야기 입니다. 

 

vscode 에서 만난 생소한 너란 녀석!

첫번째 방법

python 환경에 익숙하지 않다 보니 사실 python 2.x 와 python 3.x 가 공존하는 것도 사실 좀 생소합니다. pip도 2.x 와 3.x 용을 따로 사용하고 있고 python 환경에서 코드를 구동할 때 어떤 버전의 환경에서 구동되는 것인지 헷갈릴 때가 많습니다. 어찌되었건 돌아가는 환경이 준비되면 필요한 코드를 만드는데 집중하는 식이긴 하지만 여러가지로 찜찜한게 현실입니다. 물론... 이 현실을 타개할 것이냐는 다른 이야기죠 ㅎㅎ

 

오늘 새로운 코드 작업이 필요하여 저장소를 만들고 기존에 만들었던 코드를 기반으로 보일러 플레이팅하여 코드 작업을 시작했습니다. 그런데 왠지 모르게 계속 import 구문에서 가져온 모듈에 물결표시가 생기면서 unreolved import warning 에러가 눈에 띄었습니다. 코드는 동작하긴 하는데 vscode 에서 자동완성 같은 기능들이 삐그덕 거리는 느낌이 들었습니다. 수소문해보니 해결 방법은 여러가지이지만 가장 간단했던 방법을 소개합니다. 

 

1) Ctrl + Shift + P 혹은 Cmd + Shift + P 를 누릅니다.

2) 창에 Python Select Interpreter 를 입력하고 선택합니다

 

3) 사용중인 Python 버전에 맞는 경로를 선택해 줍니다

 

이렇게 하면 vscode 에서 거슬리는 unresolved import warning 을 없앨 수 있습니다. 이렇게 지정한 Python 경로는 vscode 의 개별 과제별 환경 파일인 .vscode 경로 하위의 settings.json 에 기록됩니다. 거꾸로 얘기하면 이 파일을 직접 수정해도 동일한 효과를 얻을 수 있다는 말입니다. 저라면 Cmd + Shift + P 를 이용하는 방법을 계속 쓸 것 같습니다 ㅎㅎ

 


두번째 방법

위와 같이 해결되었다면 다행이지만 그렇지 못한 경우도 가끔 생깁니다. 이 때는 Visual Studio Code 의 인텔리센스 관련한 기능 동작에 문제가 있는 것일수도 있습니다. VIsual Studio Code 에서 문제가 되는 프로젝트를 열어둔 상태에서 Shift - Command - P 를 누릅니다. (윈도우에서는 Shift - Ctrl - P 일까요? 윈도 쓴지가 오래되서... ㅜㅜ) 

 

화면에 검색창이 나오면 Language Specific 이라고 치고 자동 완성되 목록에서 (아마도) 첫번째 항목인 "Configure Language Specific Settings..." 를 선택해 줍니다. 곧바로 사용중인 언어를 선택하는 창이 나옵니다. python 을 입력하여 python 으로 언어를 선택하겠습니다.  그러면 settings.json 파일이 로드되는 것을 확인할 수 있습니다. 

 

 

이때 열리는 settings.json 파일은 프로젝트와 관련된 파일이 아니고 Visual Studio Code 의 언어별 기본 설정입니다. 이 파일의 내용들 중 인텔리센스와 관련된 항목을 발견할 수 있는데요, 이 항목을 과감히 삭제하고 저장해 줍니다. 제 경우에는 "python.jediEnabled" 항목을 통째로 날려주었습니다 :-)

이제 프로젝트를 열어둔 Visual Studio Code 창을 닫고 다시 프로젝트를 열어보겠습니다. (아마도) Unresolved Import Error 가 사라졌을겁니다. 후훗.

 

 

[ 혼공파 - 게으른 저는... 사두고 보진 않습니다만... 여러분들은 잘 하실겁니다 ]

 

혼자 공부하는 파이썬:파이썬 최신 버전 반영

COUPANG

www.coupang.com

본 포스팅은 소정의 수수료를 지급받을 수 있습니다

728x90
728x90

완전정복은 사실 아닙니다만... 

 

AWS 를 사용하면서 가장 많이 나오는 요금은 무엇일까?

어떤 자원을 어떤 형태로 사용하느냐에 따라 달라지겠지만

일반적인 웹 서비스라고 가정했을 때 

역시 가장 큰 비용을 차지하는 것은 네트워크 전송요금이다

 

AWS 의 과금체계는 깨알같다

컴퓨팅과 같은 상품도 당연히 그러하지만

데이터 전송과 관련한 요금은 더욱 깨알같다

 

Region 내의 데이터 전송만 생각해봐도 케이스가 정말 많다

같은 Region 내에서의 전송은 무료인가?

같은 Region 내에서 가용성 영역이 다르면 유료인가?

ELB 가 앞단에 있다면 요금은?

ELB 에 물린 서버가 크로스 존이면 또 다른가?

EC2 가 직접 응답하는 것과 ELB 경유 응답의 가격 차이는? 등등...

 

이걸 한장에 정리해 놓은 그림이 바로 아래의 그림이다.

그림의 출처는 https://github.com/open-guides/og-aws#aws-data-transfer-costs

 

출처 ; https://github.com/open-guides/og-aws#aws-data-transfer-costs

Cost Explorer 에서 과금 내역을 살펴보면서

DataTransfer 관련한 요금이 많이 나오고 있다면

어느 항목에서 요금이 많이 청구되는지 꼭 분석하자

그리고 그 요금을 낮출 방법을 찾아봐야 한다.

 

상황에 따라서는 요금을 낮추기 위해 데이터의 플로우 변경이 필요할 수도 있다.

개발된 산출물의 변경 개발이 필요할 수도 있다.

그래도 하자. 그래야... 한다.. ㅎㅎ

 

 

 

 

728x90
728x90

쉘에서 로그와 같은 텍스트 파일을 다룰때 정규표현식을 자주 사용하게 됩니다. 정규표현식을 지원하는 쉘의 도구들은 여러가지가 있는데요 오늘은 awk 에서 정규표현식을 사용하는 방법을 간단하게 살펴보겠습니다. 

 

// 일반적인 awk 의 사용 : 첫번째 컬럼 값이 server 인 경우 행($0)을 그대로 출력
$ cat my.log | awk '$1="server" { print $0 }'

// 정규표현식을 만족하는 행 찾기 (Positive Match) : /beta/
$ cat my.log | awk '/\/beta\// { print $0 }'

// 정규표현식을 만족하지 않는 행 찾기 (Negative Match) : /beta/ 가 아닌 경우
$ cat my.log | awk '!/\/beta\// { print $0 }'

 

일반적으로 awk 는 독립적으로 사용되지 않고 cat 과 같은 다른 명령과 파이프(|)로 연결해서 문자열을 다룹니다. 위 코드의 첫번째 예시는 awk 가 델리미터 단위로 행을 분할해주는 기능을 이용하여 첫번째 컬럼($1)의 값이 만족하는 경우 해당 행을 출력하는 명령입니다. 

 

정규표현식을 이용하려면 슬래시로 정규 표현식 문자열을 넣어주면 됩니다. 가령 URL 에 /beta/ 라는 path 가 존재할 수 있고, 해당 항목이 있는 경우만 출력한다면 \/beta\/ 로 표현식을 만들면 됩니다. 두번째 예시를 참고하시면 되겠습니다.

 

정규표현식을 만족하지 않는 Negative Match 로 자료를 찾아야 하는 경우도 있습니다. 이때는 정규 표현식을 감싸고 있는 슬래시의 앞에 느낌표(!)를 붙여주기만 하면 됩니다. 

728x90
728x90
  •  모든 전송 요금은 Region 단위로 과금
    • ELB - EC2 구조를 사용하더라도 Region 전송 비용을 과금함
    • Operation 이 두가지가 잡히는데 어떤 것이 실제 과금에 사용되는 지는 잘 모르겠음

DataTransfer-Out-Bytes 에 두가지가 보인다

  • ELB 는 그럼에도 전송량에 독립적이지는 않음
    • ELB 는 Processed Byte 기준으로 LCU 를 계산하여 단위 요금에 곱하여 과금
    • LCU 는 ELB 타입별로 (ALB, NLB, CLB) 측정 대상 데이터가 상이함

NLB 의 LCU 세부 정보

  • Direct Connect 도 전송량 단위로 과금함
    • 두가지 항목이 있고 과금 여부는 아래와 같음
      • #region명#-#DX_region명#-DataXfer-In : 비과금 (AWS 소스 Region 입장에서 Inbound)
      • #region명#-#DX_region명#-DataXfer-Out : 과금 (AWS 소스 Region 입장에서 Outbound)

여러가지로 복잡

  • NLB 의 동작 방식에 따른 과금 변경
    • NLB 의 Target 을 Instance ID 로 지정 : DSR 로 동작 (EC2 Outbound 요금)
    • NLB 의 Target 을 IP 로 지정 : Proxy 로 동작 (ELB Outbound 요금)
    • 참고 :  https://blog.leedoing.com/116
 

AWS NLB(Network Load Balancer)

AWS NLB는 AWS Load Balancer에 Elastic IP(고정)을 부여할 수 있는 현재까진 유일한 Load Balancer 이다. TCP 레이어를 지원한다. 따라서 http cookie 방식의 sticky는 지원하지 않으며, tcp 세션을 350초 유지한..

blog.leedoing.com

 

 

728x90

+ Recent posts