컴퓨터 110

디자인패턴 - 디자인패턴(Design Pattern)에 대하여 알아보자

정보처리기사를 공부할 때 디자인패턴이라는 개념을 접하게 되었습니다. 소프트웨어를 만들 때 여러 개발자가 협업하고 코드를 효율적으로 관리하기 위한 하나의 방법입니다. 디자인 패턴이 왜 중요하고 GoF(Gang of Four)의 23가지 디자인 패턴을 간단한 설명과 함께 알아보려고 합니다. 왜 디자인패턴이 필요할까?여러 사람이 함께 하나의 소프트웨어를 개발할 때 큰 어려움 중 하나는 다른 사람의 코드를 이해하는 것입니다. 다른 사람이 작성한 코드를 파악하고 수정하거나 기능을 추가하는 과정은 자칫하면 예상치 못한 버그를 발생시키거나 성능을 저하할 수도 있습니다. 디자인 패턴은 소프트웨어 설계 문제에 대한 검증된 해결 방법 모음이자 개발자 간의 효율적인 의사소통 방법입니다. 특정 패턴을 적용했다는 것만으로도 코..

Python (28) - 오버로딩(Overloading)과 오버라이딩(Overriding)

객체지향 프로그래밍(OOP)에서 자주 등장하는 개념 중 하나가 오버로딩과 오버라이딩입니다.이 둘의 이름은 비슷하지만, 개념과 사용 방식은 전혀 다릅니다.보통 Java나 C++로 설명하지만 파이썬을 기준으로 두 개념을 설명하려 합니다. 오버로딩 (Overloading) 오버로딩은 같은 함수 이름을 사용하지만, 매개변수의 타입이나 개수에 따라 다르게 동작하도록 하는 기법입니다. Java나 C++ 같은 언어는 함수 오버로딩을 기본적으로 지원하지만, 파이썬에서는 오버로딩을 지원하지 않으며 multipledispatch 패키지를 사용하여 구현할 수 있습니다. 패키지 설치pip install multipledispatch 사용예시from multipledispatch import dispatch@dispatch(i..

컴퓨터/Python 2025.05.04

LLM (1) - 로컬에서 LLM을 사용해보자 (Ollama 설치 및 실행)

요즘 직장에서 LLM 연구를 진행하고 있습니다. LLM 서비스를 만드는 사람들에게 조금이라도 되고자 시리즈를 작성합니다. OllamaOllama는 로컬에서 LLM을 실행하기 위해 설계된 프로그램입니다. 로컬에서 LLM을 실행함으로 데이터 보안 및 비용 절감 등 여러 가지 이점을 가집니다. 특히 GGUF 포맷의 파일만 있으면 Hugging Face에 올라온 수많은 AI를 돌릴 수 있다는 장점을 가집니다. 설치 방법은 다음과 같습니다. 1. 하단의 링크로 접속 후 프로그램을 다운로드합니다.https://ollama.com/download Download Ollama on macOSDownload Ollama for macOSollama.com 추가로 PowerShell로 다운로드하는 방법도 공유합니다.In..

컴퓨터/LLM 2025.04.24

네트워크 - OSI 7 Layer에 대해 알아보자

네트워크를 공부하다 보면 OSI 7 Layer를 반드시 마주치게 됩니다. 각 계층이 담당하는 역할을 따라가다 보면 네트워크의 동작 방식뿐 아니라 문제 해결, 보안, 장비 이해까지 알 수 있습니다. 이 계층 구조는 단순한 이론이 아니라, 실무에서 발생하는 거의 모든 네트워크 상황을 알 수 있는 기준입니다. OSI 7 계층OSI(Open Systems Interconnection) 7 Layer 모델은 ISO(국제표준화기구)에 정의한 네트워크 모델입니다. 서로 다른 시스템 간 통신이 원활히 이뤄지도록 네트워크 통신 과정을 7단계로 나누었으며, 계층마다 특정한 역할을 가지고 있습니다. 각 계층의 서로 다른 역할을 수행하며 다음 표와 같습니다.계층이름주요 역할사용 예시7응용 계층 (Application Laye..

포트포워딩 - 로컬 서버를 외부에 공개해보자

프론트엔드 강의에서는 웹서버를 구축하고 자신의 로컬 네트워크에서 이를 확인하는 실습이 나옵니다. 하지만 자신의 컴퓨터에서만 접속할 수 있다면, 실제 서비스 환경과 거리가 있습니다. 여기서 해당 서버를 외부에서 접속할  방법을 소개하려고 합니다. 포트포워딩이란?포트포워딩(Port Forwarding)은 외부에서 들어오는 접속 요청을 내부 네트워크의 특정 기기로 전달하는 기술입니다. 외부 사용자가 특정 주소와 포트로 접속하면, 공유기가 해당 요청을 내부 네트워크의 특정 컴퓨터와 포트로 연결해 주는 구조입니다. 이를 통하여 로컬 서버 데이터를 외부에 노출시키고 실제 서비스처럼 사용할 수 있습니다. 웹사이트를 외부로 공유하자※ 파이썬의 flask, iptime 공유기를 이용하여 작업을 진행하였습니다. 1.컴퓨터..

Python (27) - PC에서 유튜브 음악을 실행해보자 (pytubefix)

디스코드에서 유튜브 링크를 올리면 오디오로 실행해 주는 챗봇이 있습니다. 해당 프로그램처럼 PC에서 유튜브 음악 플레이어로 실행 방법을 소개하려고 합니다. 파이썬을 이용해서 쉽게 유튜브 비디오를 다운로드 및 활용하는 방법이 있어 공유하려고 합니다. 글을 시작하기 전 유튜브 영상을 다운로드 후 개인소장 하는 것은 불법이 아니지만 영리를 목적으로 동영상을 이용하면 저작권 위반에 걸릴 수 있습니다. 사용하는 라이브러리라이브러리 이름사용이유pytubefix유튜브 동영상을 다운로드하기 위함os폴더 처리 관련 pydub오디오 파일 변환 및 처리 작업을 위함simpleaudio오디오를 실행하기 위함 유튜브 다운로드 및 실행1. CMD에 명령어를 입력하여 패키지를 다운로드합니다.pip install pytubefix ..

컴퓨터/Python 2025.03.10

Oracle (8) - 커서(Cursor)

오라클을 사용하다 보면 여러 행의 데이터 처리해야 하는 경우가 있습니다.  커서를 활용하면 효율적으로 데이터를 다룰 수 있습니다. 커서는 데이터를 반환하는 것뿐만이 아니라 데이터를 한 행씩 읽으면서 특정 로직을 적용하거나 조건에 맞게 가공할 수 있습니다. 프로시저나 트랜잭션 작업에서 데이터를 유연하게 처리할 수 있습니다. 커서(Cursor)커서는 SQL의 데이터 셋을 순차적으로 접근할 수 있는 메모리 영역입니다. 이를 이용하여 쿼리 결과를 한 행씩 처리할 수 있도록 합니다. 쉽게 말하면 C에서 포인터와 같은 기능을 합니다. 이를 활용하면 다음과 같은 이점을 얻을 수 있습니다.다중 행 처리: 여러 행의 데이터를 한 번에 여러 행을 반환하거나 각 행을 개별적으로 처리할 수 있습니다.복잡한 로직 구현: 프로시..

컴퓨터/Oracle 2025.01.09

Oracle (7) - 인덱스를 타는지 확인하는 방법 (EXPLAIN PLAN)

SQL을 작성하여 어떤 데이터를 만들기 위해 많은 JOIN 및 서브쿼리를 하게 되는 경우가 있습니다. 해당 과정을 반복하다 보면 쿼리 실행시 성능 문제가 발생할 수 있습니다. 특히 인덱스를 타지 못하고 FULL SCAN 하는 경우 성능이 크게 떨어집니다. 이러한 문제를 해결하기 위해 EXPLAIN PLAN을 이용하여 쿼리의 실행 계획을 확인하고, 인덱스를 잘 활용하도록 최적화하는 방법을 알아보겠습니다. EXPLAIN PLAN-- 실행 계획을 생성EXPLAIN PLAN FORSELECT * FROM TEST WHERE MAJOR = '국문학과';-- 생성된 실행 계획 확인SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);우선 EXPLAIN PLAN은 오라클에서 제공하는 기능으로, ..

컴퓨터/Oracle 2024.12.28

무선통신 - 2.4GHz / 5GHz 대역이 면허 없이 사용 가능한 이유

최근 집에서 보일러가 꺼지거나 전자레인지가 사용할 때 TV 신호에 간섭이 발생하는 경우가 있었습니다. 이에 대해 인터넷을 찾아보던 중 자유 주파수 대역이라는 개념을 알게 되었습니다. ISM 대역우선 국제전기통신연합(ITU)은 산업, 과학, 의료 분야에서 사용하기 위한 특정 주파수 대역을 ISM 대역으로 지정하였습니다. 이를 ISM 대역(Industry-Science-Medical Band)이라고 합니다. 일반적으로 주파수 할당을 위해서는 특정 사업자가 주파수 면허를 발급받아야 하지만, ISM 대역은 누구나 사용할 수 있도록 개방되어 있습니다. 대한민국에서 사용 가능한 ISM 대역대한민국에서 허용된 ISM 대역은 국제기준과 거의 동일하나, 일부 대역폭(433MHz, 902MHz) 대역폭은 지정되어 있지 않..

Python (26) - Flask를 활용하여 웹서버를 만들어보자

파이썬을 백엔드로 사용하여 웹사이트를 구축할 수 있습니다. 소규모 프로젝트에 적합한 파이썬 기반 웹 프레임워크인 Flask에 대하여 알아보겠습니다. FlaskFlask는 파이썬 기반의 마이크로 웹 프레임워크로 간편하게 웹 애플리케이션을 개발할 수 있도록 도와줍니다. Flask는 Werkzeug WSGI 툴킷과 Jinja2 템플릿 엔진을 기반으로 하고 있습니다. 필요한 기능만 포함하고 있어 가볍고 빠릅니다. 뛰어난 확장성을 바탕으로 사용자가 원하는 기능을 쉽게 추가할 수 있는 유연성을 제공합니다. Flask의 특징간결성:  코드가 적고 직관적이고 짧아,  적은 코드만으로 웹사이트를 개발할 수 있습니다.확장성:  DB연동, 그래프 추가 등 다양한 기능을, 플러그인을 통하여 원하는 기능을 쉽게 추가할 수 있습..

컴퓨터/Python 2024.11.07