Uvicorn & Gunicorn
Uvicorn and GunicornUvicorn and Gunicorn are important concepts when developing applications in Python. However, there are many concepts to be aware of in order to fully understand Uvicorn and Gunicorn. The following is a brief summary of the necessary concepts, and the details will be dealt with separately later.Necessary ConceptsStarletteStarlette is a Web application server that can run asynchronously. Starlette runs on top of Uvicorn.FastAPIFastAPI provides many features on top of Starlet...
Gas optimization in Solidity, Ethereum
I’m sorry but my English is terrible. I hope you understand that generously.Recently, I was developing a toy project named Blind Market. It’s a simple P2P trading application using smart contract. I was making a contract using Solidity, and the trade stage proceeded in the order of pending, shipping, and done. The problem was appeared in done phase. The problem was that when I tried to close the transaction by paying the price raised by the seller in msg.value, the following error occurred.Pe...
P2WPKH
P2WPKHP2WPKH란 비트코인 내에서 가장 일반적인 스크립트 형식으로 비트코인 프로토콜에 대한 지불 거래 유형이다. 주소는 1로 시작하는데, 세그윗을 지원하는 새로운 주소 3 또는 bc1로 시작하는 주소보다 훨씬 비싸다. https://mirror.xyz/0xA1d9f681B25C14C1eE7B87f1CF102E73cA3ad4d9/egjhNVklgy_LgZmcTXXAOTBa6ePBqO3Ja9ZSoDIad-8 즉, 비트코인 주소가 1로 시작하면 P2PKH 주소를 사용하고 있는 것이다. 공개키의 간단한 해시이며, 이 해시를 주소로 사용하는 것이다. 이것은 원래 비트코인 주소 형식이었으며 오늘까지도 충실히 작동한다. 레거시 주소는 세그윗과 호환되지 않지만, 여전히 문제없이 P2PKH 주소에서 세그윗 주소로 BTC를 보낼 수 있다. 그러나 레거시 주소 트랜잭션이 더 크기 때문에 P2PKH 주소에서 전송하는 평균 속도는 세그윗 주소에서 전송할 때보다 더 높은 요금이 발생할 수 있다....
Uvicorn & Gunicorn
Uvicorn and GunicornUvicorn and Gunicorn are important concepts when developing applications in Python. However, there are many concepts to be aware of in order to fully understand Uvicorn and Gunicorn. The following is a brief summary of the necessary concepts, and the details will be dealt with separately later.Necessary ConceptsStarletteStarlette is a Web application server that can run asynchronously. Starlette runs on top of Uvicorn.FastAPIFastAPI provides many features on top of Starlet...
Gas optimization in Solidity, Ethereum
I’m sorry but my English is terrible. I hope you understand that generously.Recently, I was developing a toy project named Blind Market. It’s a simple P2P trading application using smart contract. I was making a contract using Solidity, and the trade stage proceeded in the order of pending, shipping, and done. The problem was appeared in done phase. The problem was that when I tried to close the transaction by paying the price raised by the seller in msg.value, the following error occurred.Pe...
P2WPKH
P2WPKHP2WPKH란 비트코인 내에서 가장 일반적인 스크립트 형식으로 비트코인 프로토콜에 대한 지불 거래 유형이다. 주소는 1로 시작하는데, 세그윗을 지원하는 새로운 주소 3 또는 bc1로 시작하는 주소보다 훨씬 비싸다. https://mirror.xyz/0xA1d9f681B25C14C1eE7B87f1CF102E73cA3ad4d9/egjhNVklgy_LgZmcTXXAOTBa6ePBqO3Ja9ZSoDIad-8 즉, 비트코인 주소가 1로 시작하면 P2PKH 주소를 사용하고 있는 것이다. 공개키의 간단한 해시이며, 이 해시를 주소로 사용하는 것이다. 이것은 원래 비트코인 주소 형식이었으며 오늘까지도 충실히 작동한다. 레거시 주소는 세그윗과 호환되지 않지만, 여전히 문제없이 P2PKH 주소에서 세그윗 주소로 BTC를 보낼 수 있다. 그러나 레거시 주소 트랜잭션이 더 크기 때문에 P2PKH 주소에서 전송하는 평균 속도는 세그윗 주소에서 전송할 때보다 더 높은 요금이 발생할 수 있다....
Share Dialog
Share Dialog
<100 subscribers
<100 subscribers
AOP는 Aspect Oriented Programming의 약자로 관점 지향 프로그래밍이라고 불린다.
관점 지향은 쉽게 말해 어떤 로직을 기준으로 핵심적인 관점, 부가적인 관점으로 나누어서 보고 그 관점을 기준으로 각각 모듈화하겠다는 것이다.
모듈을 핵심-부가적인 관점으로 나눈다.
여기서 모듈화란 어떤 공통된 로직이나 기능을 하나의 단위로 묶는 것을 말한다.
예로들어 핵심적인 관점은 결국 우리가 적용하고자 하는 핵심 비즈니스 로직이 된다.
또한 부가적인 관점은 핵심 로직을 실행하기 위해서 행해지는 데이터베이스 연결, 로깅, 파일 입출력 등을 예로 들 수 있다.
AOP에서 각 관점을 기준으로 로직을 모듈화한다는 것은 코드들을 부분적으로 나누어서 모듈화하겠다는 의미다.
이 때, 소스 코드상에서 다른 부분에 계속 반복해서 쓰는 코드들을 발견할 수 있는 데 이것을 흩어진 관심사 (Crosscutting Concerns)라 부른다.

AOP(Aspect-Oriented Programming)는 이러한 흩어짐 관심사 문제를 핵심 비즈니스 로직에서 분리하여 해결하는 것을 목표로 하는 프로그래밍 패러다임이다.
코드의 중복을 최대한으로 회피
흩어진 관심사 문제는 로깅, 보안, 트랜잭션 관리 및 캐싱과 같은 응용 프로그램의 여러 모듈 또는 계층에 걸쳐 있는 기능이다.
위에서 부가적인 관점으로 예시를 든 코드들
기존 프로그래밍에서는 흩어진 관심사 문제가 코드 베이스 전체에 흩어져 있으므로 코드를 읽고 유지 관리하고 테스트하기가 더 어렵다.
AOP는 이러한 문제를 런타임 시 코드에 구현할 수 있는 측면으로 정의하여 모듈화하는 방법을 제공한다.
결국 AOP의 핵심 개념은 위에서 얘기한 모듈 단위의 Aspect다.
각 모듈에는 Advice와 Pointcut이 있다.
Advice란 해야 할 일, 기능을 나타내는 것이다.
Pointcut이란 어디에 적용해야 하는지를 나타내는 것이다.(ex A라는 클래스의 Go라는 메서드)
Target이란 각각 클래스를 나타내는 것이다.(클래스 A, B, C) 즉, 적용이 되는 대상을 뜻하는 용어이다.
Join point라는 용어는 끼어들 지점을 뜻한다.(ex 메서드를 실행할 때, 필드에서 값을 가져갈 때 등등)

AOP의 장점은 다음과 같다.
관심사의 분리: AOP는 핵심 비즈니스 로직에서 관심사를 분리하여 코드베이스를 보다 모듈화하고 유지 관리하기 쉽게 만든다.
재사용성: 로직을 한 번 정의하고 여러 부분에 적용할 수 있으므로 중복이 줄어들고 재사용상이 향상된다.
유연성: 런타임 시 특정 Aspect를 추가, 제거 또는 수정할 수 있으므로 변화하는 요구 사항에 대한 유연성과 적응성을 제공한다.
향상된 코드 품질: AOP는 상용구 코드의 양을 줄이고 코드의 가독성을 높임으로써 코드베이스의 품질을 향상시키는 데 도움이 될 수 있다.
AOP의 단점은 다음과 같다.
복잡성: AOP는 코드베이스에 추가 복잡성을 도입하여 디버깅이 어려워질 수 있다.
성능 오버헤드: 위빙 프로세스는 애플리케이션에 성능 오버헤드를 추가할 수 있으며, 이는 경우에 따라 중요할 수 있다.
AOP는 Aspect Oriented Programming의 약자로 관점 지향 프로그래밍이라고 불린다.
관점 지향은 쉽게 말해 어떤 로직을 기준으로 핵심적인 관점, 부가적인 관점으로 나누어서 보고 그 관점을 기준으로 각각 모듈화하겠다는 것이다.
모듈을 핵심-부가적인 관점으로 나눈다.
여기서 모듈화란 어떤 공통된 로직이나 기능을 하나의 단위로 묶는 것을 말한다.
예로들어 핵심적인 관점은 결국 우리가 적용하고자 하는 핵심 비즈니스 로직이 된다.
또한 부가적인 관점은 핵심 로직을 실행하기 위해서 행해지는 데이터베이스 연결, 로깅, 파일 입출력 등을 예로 들 수 있다.
AOP에서 각 관점을 기준으로 로직을 모듈화한다는 것은 코드들을 부분적으로 나누어서 모듈화하겠다는 의미다.
이 때, 소스 코드상에서 다른 부분에 계속 반복해서 쓰는 코드들을 발견할 수 있는 데 이것을 흩어진 관심사 (Crosscutting Concerns)라 부른다.

AOP(Aspect-Oriented Programming)는 이러한 흩어짐 관심사 문제를 핵심 비즈니스 로직에서 분리하여 해결하는 것을 목표로 하는 프로그래밍 패러다임이다.
코드의 중복을 최대한으로 회피
흩어진 관심사 문제는 로깅, 보안, 트랜잭션 관리 및 캐싱과 같은 응용 프로그램의 여러 모듈 또는 계층에 걸쳐 있는 기능이다.
위에서 부가적인 관점으로 예시를 든 코드들
기존 프로그래밍에서는 흩어진 관심사 문제가 코드 베이스 전체에 흩어져 있으므로 코드를 읽고 유지 관리하고 테스트하기가 더 어렵다.
AOP는 이러한 문제를 런타임 시 코드에 구현할 수 있는 측면으로 정의하여 모듈화하는 방법을 제공한다.
결국 AOP의 핵심 개념은 위에서 얘기한 모듈 단위의 Aspect다.
각 모듈에는 Advice와 Pointcut이 있다.
Advice란 해야 할 일, 기능을 나타내는 것이다.
Pointcut이란 어디에 적용해야 하는지를 나타내는 것이다.(ex A라는 클래스의 Go라는 메서드)
Target이란 각각 클래스를 나타내는 것이다.(클래스 A, B, C) 즉, 적용이 되는 대상을 뜻하는 용어이다.
Join point라는 용어는 끼어들 지점을 뜻한다.(ex 메서드를 실행할 때, 필드에서 값을 가져갈 때 등등)

AOP의 장점은 다음과 같다.
관심사의 분리: AOP는 핵심 비즈니스 로직에서 관심사를 분리하여 코드베이스를 보다 모듈화하고 유지 관리하기 쉽게 만든다.
재사용성: 로직을 한 번 정의하고 여러 부분에 적용할 수 있으므로 중복이 줄어들고 재사용상이 향상된다.
유연성: 런타임 시 특정 Aspect를 추가, 제거 또는 수정할 수 있으므로 변화하는 요구 사항에 대한 유연성과 적응성을 제공한다.
향상된 코드 품질: AOP는 상용구 코드의 양을 줄이고 코드의 가독성을 높임으로써 코드베이스의 품질을 향상시키는 데 도움이 될 수 있다.
AOP의 단점은 다음과 같다.
복잡성: AOP는 코드베이스에 추가 복잡성을 도입하여 디버깅이 어려워질 수 있다.
성능 오버헤드: 위빙 프로세스는 애플리케이션에 성능 오버헤드를 추가할 수 있으며, 이는 경우에 따라 중요할 수 있다.
No comments yet