쉘스크립트로 배포하기(deploy) > 리눅스서버
리눅스서버

쉘스크립트로 배포하기(deploy)

조회 195회 댓글 0건

예전에 만들어 잠깐 사용하던 배포하는 스크립트 입니다.

원격서버가 있고 사내에서 작업한 것을 배포하는 방식인데 요즘 우리가 클라우드를 통해서 배포하는것과 크게 다르지? 않다고 봅니다


쉘스크립트로 배포하기(deploy) 기본 방식은 이렇습니다.

압축을 하고 전송하고 압축을 풀어주고. 심볼릭링크를 변경하여 주며 캐쉬된것이 문제 될 수 있으면 웹서버관련된것을 재시작 시켜 주는 방식입니다.


970647bcdd7d460979d1bfb9205e94da_1685348425_0408.png
 

아래 쉘스크립트 배포하는것은 ssh를 사용하며 pssh를 사용하는것을 전제로 되어 있습니다.

그렇기 때문에 pssh가 아닌 다른것을 사용하신 다면 그에 맞게 변경하면 됩니다.


#/bin/sh

# 파라미터를 받는다. - 처리해야할 디렉토리 위치.
#args=("$@")
#echo ${args[0]} ${args[1]} ${args[2]}
#
args=("$@")
echo ""
echo "- 다음과 같은 파라미터를 받았습니다."

#
# 맨처음 한번 실행한것
# /usr/bin/pssh -h /root/pssh-hosts "cd /www/website; mv public_html srvc_html/; ln -s srvc_html/public_html public_html";
#

# --------------------------------------------------------
# 기본 환경 - 분:%M 초:%S
# --------------------------------------------------------
DATEFULL=`/bin/date +%Y-%m%d-%H%M`
DIR_DOCS_ROOT='/www/website'
DIR_REMO_SRVC='/www/website/srvc_html'
DIR_DOCS_WWW='/www/website/public_html'

# --------------------------------------------------------
# 디렉토리를 하나 만들어 주고. 대상 파일 목록을 생성 한다.
# --------------------------------------------------------
# bak-DATA-0 백업디렉토리에서 심볼릭링크 문제로 상대경로인 LIK_DIR_ROOT 를 사용 한다.
TMP_DIR_ROOT=${DIR_REMO_SRVC}/${DATEFULL}
LNK_DIR_ROOT="srvc_html/${DATEFULL}"
mkdir ${TMP_DIR_ROOT}
echo ""
echo "- 다음과 같은 기본 디렉토리를 만들었습니다."
echo "   mkdir ${TMP_DIR_ROOT}"
echo ""

# --------------------------------------------------------
# 압축을 한다.
# --------------------------------------------------------
# /usr/bin/pax -r -s ',^/,,' -f /test.tar  - 경로문제는 이런것을 쓰면 되는. 여기선 옮긴다.
# tar zcpfP /www/website/srvc_html/2020-0330-0820.tgz /www/website/public_html
#
TMP_TAR_FILE=${TMP_DIR_ROOT}/${DATEFULL}.tgz
echo "/usr/bin/tar chf - public_html/ | /usr/bin/gzip -9 > ${TMP_TAR_FILE}"
cd ${DIR_DOCS_ROOT}
/usr/bin/tar chf - public_html/ | /usr/bin/gzip -9 > ${TMP_TAR_FILE}
ls -al ${TMP_TAR_FILE}

# --------------------------------------------------------
# 서버로 올린다. - 디렉토리는 미리 있어야 한다. 그렇지 아니하면 오류가 발생한다.
# --------------------------------------------------------
echo ""
echo "- 원격서버에 임시 디렉토리를 만듭니다."
echo "   /usr/bin/pssh   -h /root/pssh-hosts -i \"mkdir -p ${TMP_DIR_ROOT}\""
/usr/bin/pssh   -h /root/pssh-hosts -i "mkdir -p ${TMP_DIR_ROOT}"

echo ""
echo "- 원격서버에 prsync로 갱신한 파일을 올립니다."
echo "   /usr/bin/prsync -h /root/pssh-hosts -ar ${TMP_DIR_ROOT}/ ${TMP_DIR_ROOT}/"
/usr/bin/prsync -h /root/pssh-hosts -ar ${TMP_DIR_ROOT}/ ${TMP_DIR_ROOT}/

# --------------------------------------------------------
# 올려진 서버에서 압축을 풀고 링크를 변경해 준다.
# --------------------------------------------------------
echo ""
echo "- 압축을 풀고 심볼릭 링크를 변경처리 합니다. "
echo "ls -al ${DIR_DOCS_WWW}; cd ${TMP_DIR_ROOT}; /usr/bin/tar xfz ${DATEFULL}.tgz; rm -f ${DIR_DOCS_WWW}; ln -s ${LNK_DIR_ROOT}/public_html ${DIR_DOCS_WWW}; ls -al ${DIR_DOCS_WWW}"
/usr/bin/pssh   -h /root/pssh-hosts -i "ls -al ${DIR_DOCS_WWW}; cd ${TMP_DIR_ROOT}; /usr/bin/tar xfz ${DATEFULL}.tgz; rm -f ${DIR_DOCS_WWW}; ln -s ${LNK_DIR_ROOT}/public_html ${DIR_DOCS_WWW}; ls -al ${DIR_DOCS_ROOT}"

# --------------------------------------------------------
# php 및 웹서버 재시작
# --------------------------------------------------------
echo ""
echo ""
echo "------------------------------------------------------------------------"
echo ""
#/usr/bin/pssh   -h /root/pssh-hosts -i "systemctl restart php74-php-fpm; systemctl restart httpd"
#/usr/bin/pssh   -h /root/pssh-hosts -i "systemctl restart php74-php-fpm; ps augx | grep php; systemctl status php74-php-fpm; systemctl restart httpd;netstat -antp | grep LISTEN; systemctl status httpd"
echo ""
echo "- 문제가 있을 경우 원격 웹서버 재시작 명령"
echo "   /usr/bin/pssh   -h /root/pssh-hosts -i \"systemctl restart php74-php-fpm; systemctl restart httpd\""
echo "   /usr/bin/pssh   -h /root/pssh-hosts -i \"systemctl restart php74-php-fpm; systemctl status php74-php-fpm; systemctl restart httpd; systemctl status httpd\""
echo "   네트웍 열린포트 보기: /usr/bin/pssh   -h /root/pssh-hosts -i \"netstat -antp | grep LISTEN\""
echo ""
echo "전체 서버 php 재시작 합니다......."
/usr/bin/pssh -h /root/pssh-hosts "systemctl restart php74-php-fpm"

#
# 웹서버에서 실행하여 캐쉬를 삭제 한다.
#
echo "OCP캐쉬삭제: /www/shellscript/php_ocp_cache_reset.sh > /dev/null & "
/www/shellscript/php_ocp_cache_reset.sh > /dev/null &

# --------------------------------------------------------
# 이전으로 돌려야하는 경우 링크 돌려주기
# --------------------------------------------------------
# [root@www 2020-0330-0903]# readlink /www/website/public_html
#/www/website/srvc_html/2020-0330-0903
echo ""
echo "- 현재 www 디렉토리 현황 확인"
#RE_DIR=`readlink -f /www/website/public_html`
echo "웹브라우저 사이트확인: https://www.test.com/chk.php"
echo "/usr/bin/pssh -h /root/pssh-hosts -i \"ls -al ${DIR_DOCS_WWW}\""
echo ""
echo "-----------------------"
echo "- 원복 할 명령 입니다."
echo "-----------------------"
echo "/usr/bin/pssh -h /root/pssh-hosts -i \"rm -f ${DIR_DOCS_WWW}; ln -s 이전경로 ${DIR_DOCS_WWW}; ls -al ${DIR_DOCS_WWW} \""
 


  • 페이스북으로 공유
  • 트위터로  공유
  • 구글플러스로 공유
전체 122건 1 페이지
  • profile_image 메시지 내용을 잘 확인 하면 알 수 있습니다. mysql 1593은 식별하는 장치의 id 값이 같아서 생긴 문제 입니다.즉, 마스터의 server-id 값과 슬레이브의 server-id 값이 같아서 생긴 문제 입니다.다르게만 하면 됩니다. 그리고 아래 2번 부터는 문제가 생길수도 있고 안생길 수도 있습니다. 재시작 하면 파일이 다시 생기기 때문에 생길 가능성이 높습니다.조치 방법은1) 마스터의 서버id 변경환경설정의 [mysqld] 하위에 마스…
  • profile_image 리플리케이션(복제) 설정으로 이루어진 MySQL 데이터베이스 구조에서 슬레이브쪽에서 오류가 발생되는 경우에서 흔하게 발생하지 않는것중 하나인 1594에 관한것입니다. 이 오류는 경험이 없을 경우 서버리스가 아니라면 시스템에서 백업을 받아 놓은뒤 복구 하는것을 권장 합니다. 슬레이브 상태 오류코드('SHOW SLAVE STATUS' on this slave. Error_code: 1594) 1594 오류에 관한 것인데 주의 사항만 적고 싶어서 작…
  • profile_image 주로 데이터를 입력할때의 특징에 대한것으로 엄격하게 관리를 할거냐 아니면 일부 문제가 있어도 문제가 될것이 크지 않기 때문에 생산성 위주로 할것이냐에 대한것으로 보시면 됩니다. 데이터의 문제는 입력하는 프로그램 단계에서 검증을 하는 방법이 있겠지만 최종적으로 입력되는 데이터베이스에서 관리를 하게 되면 더 완벽하게 됩니다. 문제는 어떤것이든 쉽게 얻어 지는 것은 없으니 그에 대한 댓가가 있습니다. 이 댓가가 어느쪽이 더 이익이 되느냐의 문제 이겠…
  • profile_image 기본적으로 AL2(아마존리눅스2)나 CentOS7 이상에서 기본적으로 설치되는 메일 서버인 postfix에 대해 사용하지 않는 방법에 대한 것입니다. 그리고 AWS는 SES라는 메일 서비스가 있으며 기본적으로 EC2에선 허용되지 않기 때문에 필요하면 별도 허가를 받기전에는 사용할 수 없습니다. 사용하지 않는 postfix 메일 서버 내리기 아래와 같이 사용하지 않는 메일 포트가 있는 경우 AL2나 CentOS에서는 postfix라는 메일 프로그…
  • profile_image 마스터에 생성되는 바이너리 로그 삭제에 대한 것이다.  MySQL, 마리아DB 바이너리 로그 실시간 삭제 마스터 슬레이브 구조에서 슬레이브에서 데이터를 가져가기 위해서 필요한것이 마스터에서 생성되는 바이너리 로그인데 너무 많아 지면 용량이 부족하여 더 큰 문제가 발생 할 수 있기 때문에 이에 대한 관리가 필요하다. 날짜 설정 /etc/my.cnf에서 설정하면 재시작해야 적용이 되기 때문에 재시작 없이 적용을 시키고 싶은 경우 이렇게 해주면 된다…
  • profile_image 불필요한 레포티지를 굳이 가지고 있을 필요는 없습니다. 또는 실수로 설치하는 문제등을 가지고 있기 때문에 필요한 것이 아니면 삭제를 하는것이 좋은데 yum에서 삭제하는 명령이 없기 때문에 수작업으로 삭제 하는 방법에 대한 것입니다. 활성화된 yum 리포티지 목록 보기 및 삭제 현재 설치가 된것이 무엇인지 확인 합니다. yum repolist예를 들어 remi 패키지를 삭제 할 경우  환경 파일 삭제 cd /etc/yum.repos.d/ rm -…
  • profile_image 아마존리눅스 설치하게 되면 기본 타임존이 UTC 입니다. 그렇기 때문에 국내에서 사용하게 되면 KST로 변경을 해줘야 하는데 아래는 그 방법 입니다.AL2, AL2023 등 현재까지의 모든 버전에서 변경하는 방법은 동일 합니다.AWS 리눅스 타임존 변경( UTC -> KST) AWS에서 제공하는 리눅스를 설치하면 타임존이 UTC로 되어 있어 국내와 맞지 않는 문제로 변경을 해서 사용해야 한다. 타임존 변경 방법1) 변경 방법은 다음과. 같…