본문 바로가기

728x90

리눅스

GitLab을 Docker Compose를 사용하여 올리는 방법 GitLab을 Docker Compose를 사용하여 올리는 방법 gitlab 디렉토리 생성 mkdir -p gitlab gitlab 디렉토리 소유자 설정 chown -R 999:999 gitlab gitlab 디렉토리 권한 설정 chmod -R 755 gitlab Docker Compose 파일 작성 vim docker-compose.yml version: '3.8' services: ### 16.10.1-ee.0 gitlab: image: gitlab/gitlab-ee:latest container_name: gitlab restart: always hostname: gitlab.sangchul.kr #env_file: .env environment: GITLAB_OMNIBUS_CONFIG: | ext.. 더보기
우분투에서 Certbot을 사용하여 Let's Encrypt SSL 인증서를 생성하는 방법 우분투에서 Certbot을 사용하여 Let's Encrypt SSL 인증서를 생성하는 방법 Certbot 설치 우분투 패키지 관리자를 사용하여 Certbot을 설치합니다. sudo apt-get update sudo apt-get install -y certbot certbot --version $ certbot --version certbot 1.21.0 인증서 발급 Certbot을 사용하여 SSL 인증서를 발급합니다. 도메인 이름은 실제 도메인으로 변경해야 합니다. sudo certbot certonly --standalone --agree-tos --email email@example.com -d testssl.example.com 더보기 --- $ sudo certbot certonly --sta.. 더보기
Portainer를 설치하고 컨테이너를 관리하는 방법 Portainer를 설치하고 컨테이너를 관리하는 방법 Portainer는 Docker 컨테이너를 관리하기 위한 오픈 소스 웹 기반 관리 도구입니다. Portainer를 사용하면 사용자는 직관적인 사용자 인터페이스를 통해 Docker 호스트, 컨테이너, 이미지, 네트워크, 볼륨 등을 관리할 수 있습니다. 일반적으로 개발자, 시스템 관리자, DevOps 엔지니어 등이 Docker 환경을 관리하고 모니터링하는 데 사용됩니다. Portainer의 기능 시각적인 인터페이스 : Docker의 명령줄 인터페이스(CLI) 대신 웹 기반 인터페이스를 통해 Docker 리소스를 관리할 수 있습니다. 컨테이너 관리 : 컨테이너의 생성, 시작, 중지, 제거 등을 수행할 수 있습니다. 이미지 관리 : Docker 이미지를 검색.. 더보기
AWS EC2 인스턴스에 새로운 사용자를 추가하고 패스워드로 SSH 접속을 허용하는 방법 AWS EC2 인스턴스에 새로운 사용자를 추가하고 패스워드로 SSH 접속을 허용하는 방법 EC2 인스턴스에 SSH로 접속 ssh -i your-key.pem ec2-user@your-instance-public-ip 새로운 사용자 새로운 사용자를 EC2 인스턴스에 추가합니다. 예를 들어, newuser라는 사용자를 추가하려면 다음 명령을 실행합니다. useradd -m -c "new user" -d /home/newuser -s /bin/bash newuser echo 'newuser:newuser' | sudo chpasswd echo 'newuser ALL=(ALL) NOPASSWD: ALL' > /etc/sudoers.d/newuser SSH 암호 로그인 허용 설정 변경 비밀번호로 SSH 암호 로그.. 더보기
우분투에서 Docker 컨테이너 내에서 systemd를 실행하는 방법 우분투에서 Docker 컨테이너 내에서 systemd를 실행하는 방법 Docker 컨테이너 내에서 systemd를 실행하는 것은 기본적으로 권장되지 않지만 가능합니다. systemd를 사용하려면 컨테이너가 호스트의 init 프로세스로 설정되어야 합니다. Dockerfile 작성 vim Dockerfile FROM ubuntu:22.04 # systemd를 사용할 수 있도록 환경 변수 설정 ENV container docker # 패키지 설치 및 설정 RUN apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y \ systemd \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* /tmp/* /va.. 더보기
NGINX 및 PHP-FPM에서 파일 업로드 크기를 늘리는 방법 NGINX 및 PHP-FPM에서 파일 업로드 크기를 늘리는 방법 NGINX 설정 변경 NGINX에서 클라이언트가 업로드하는 파일 크기를 제한하는 것은 client_max_body_size 디렉티브를 사용합니다. 원하는 파일 크기로 설정해야 합니다. 기본값은 1MB입니다. vim /etc/nginx/nginx.conf http { ... client_max_body_size 100M; ... } 이 설정은 NGINX의 설정 파일에 위치하며 업로드한 파일의 최대 크기를 100MB로 제한합니다. NGINX 재시작 변경된 NGINX 설정이 적용되려면 NGINX 서비스를 다시 시작해야 합니다. sudo systemctl restart nginx PHP-FPM 설정 변경 기본 설정(Default Value) max.. 더보기
우분투에서 IPv6를 비활성화하는 방법 우분투에서 IPv6를 비활성화하는 방법 임시로 비활성화하기 시스템을 다시 부팅하면 IPv6가 다시 활성화됩니다. IPv6를 임시로 비활성화 sudo sysctl -w net.ipv6.conf.all.disable_ipv6=1 sudo sysctl -w net.ipv6.conf.default.disable_ipv6=1 이렇게 하면 현재 세션에서만 IPv6가 비활성화됩니다. 영구적으로 비활성화하기 시스템을 다시 부팅해도 IPv6가 비활성화됩니다. /etc/sysctl.conf 파일을 편집 sudo vim /etc/sysctl.conf 파일의 맨 끝에 다음 라인을 추가합니다. net.ipv6.conf.all.disable_ipv6 = 1 net.ipv6.conf.default.disable_ipv6 = 1 변.. 더보기
우분투에서 cron 작업에 대한 로그를 별도의 파일로 분리하는 방법 우분투에서 cron 작업에 대한 로그를 별도의 파일로 분리하는 방법 1. rsyslog 설정 변경 cron 로그를 별도의 파일로 보내도록 rsyslog를 구성해야 합니다. sudo vim /etc/rsyslog.d/50-default.conf default rsyslog(50-default.conf) 더보기 --- cat /etc/rsyslog.d/50-default.conf # Default rules for rsyslog. # # For more information see rsyslog.conf(5) and /etc/rsyslog.conf # # First some standard log files. Log by facility. # auth,authpriv.* /var/log/auth.log *... 더보기

728x90