使用git做服务器端代码的部署

55次阅读

传统部署方案
     windows 远程桌面
     FTP/SFTP
      登录服务器 pull github 代码
     Phing(PHP 专业部署工具)

git 自动部署流程图
     

使用git做服务器端代码的部署插图
 

服务器端准备工作:
     0. 这些工作都在 root 或有管理权限的帐号下进行,下面以 root 为用户,切换到其他用户的时候会提示
     1. 确保安装了 git
     2. 为了安全起见,新建一个专门用于代码部署的无特权用户
                useradd -m deployuser
                passwd deployuser #设置该用户的密码,也可根据喜好配置成免密码登陆
     3. 新建一个目录作为要部署代码的根目录,如:
                mkdir /var/www/html/deploy
     4. 将这个目录的属主和属组都改为上面新建的用户 deployuser
                cd /var/www/html
                chown deployuser:deployuser deploy
     5. 切换到部署代码的专用用户
                su deployuser
     6. 进入项目根目录,初始化为 git 仓库
                cd deploy
                git init
     7.【重要】让仓库接受代码提交
                git config receive.denyCurrentBranch ignore
                [可选] git config core.worktree ~/www
                [可选] git config –bool receive.denyNonFastForwards false #禁止强制推送
      至此,一个空的 git 仓库就在服务器上建好了,仓库的地址为:
                ssh://deployuser@ipaddress/var/www/html/deploy/.git

本地仓库准备工作:
     1. 通过 git clone 或 git pull 从 github 仓库上将代码获取到本地
     2. 将服务器添加到远程仓库列表,使用名字来区分不同的服务器,如测试服务器可以叫做 testing
                git remote add testing ssh://deployuser@ipaddress/var/www/html/deploy/.git
     3. 将本地代码提交到测试服务器上面
                git push testing master

回到服务器端:
    1. 更新服务端 git 仓库状态并检出文件
                cd /var/www/html/deploy
                git update-server-info

                git checkout -f
        OR:
                git checkout branch_name # 如果 push 的不是 master 分支

    2. 检查是不是将文件更新进来了
    3. 设置服务器端更新钩子 post-update
              cd .git/hooks
        新建 post-receive 或将 post-receive.sample 重命名为 post-receive
              touch post-receive
       OR:
              mv post-receive.sample post-receive
              vim post-receive
        将如下内容复制到文件中
                 #!/bin/sh
                 unset GIT_DIR
                 cd ..
                 git checkout -f
        注: 第 3 步的操作将 post-receive 替换为 post-update 也可以, 不过需要先将 post-update 中的 exec git update-server-info 这一行删掉

后续代码的更新:
     1. github 有更新的时候 pull 更新本地部署仓库
     2. 然后本地先 push 到测试服务器进行测试
     3. 测试通过之后 push 到正式服务器进行上线
     4. 代码的回滚:
               * 服务器端回滚:推荐 git reset –hard HEAD^
                本地仓库回滚:无需登陆服务器即可实现代码回滚,git reset HEAD^ 保留代码回滚,然后使用 git push remote_name local_branch_name -f 强制推送

使用过程中需要注意的问题:
     1. 需要约定好 git 不能更新的操作要怎么处理,比如新增数据库的字段,新安装必要的扩 …

原文链接:https://www.cnblogs.com/shaohuixia/p/5503521.html

正文完
 
追风者
版权声明:本站原创文章,由 追风者 2024-01-02发表,共计2179字。
转载说明:声明:本站内容均来自互联网,归原创作者所有,如有侵权必删除。 本站文章皆由CC-4.0协议发布。