<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                轉載于:[https://learnku.com/articles/33689](https://learnku.com/articles/33689) 簡介 在我們的開發過程中,我們不可避免的會用到版本控制。當然,這也致使你對 Git 和 SVN 有所了解。兩者都是出色的版本控制工具,我個人比較習慣用 Git,當然這可能和個人習慣有關。不知道大家一開始是怎么使用 git 進行開發的,反正我個人是先將代碼提交到 github 倉庫,然后用 SSH 登錄到服務器,然后進行克隆或者版本更新。聽起來就很麻煩,當然實際操作中也很麻煩,那么有什么可以 “一勞永逸 “ 的辦法呢?請往下看! 簡單使用 Git 鉤子 什么是 git 鉤子呢?官方解釋有些長,簡單來說就是一個在特定環境下觸發的腳本。這個解釋可能不太準確,但是我認為這樣更容易理解一些,想了解更多的,可以去 Git 官網查看,下面我們就用鉤子實現自動化部署。 第一步:創建 git 用戶 登錄我們的服務器,這里默認你已經安裝好了 git。創建一個 git 用戶: # 創建一個名叫jouzeyu的用戶 adduser jouzeyu 第二步:給 git 用戶添加權限 #在根目錄下的 home 文件夾下創建一個git文件夾 mkdir /home/git #切換到創建好的git文件夾 cd /home/git #創建 .ssh文件夾,里面主要用來放公鑰 mkdir .ssh #切換到.ssh文件夾并創建authorized_keys文件 cd .ssh touch authorized_keys 第三步:配置 git 并獲取公鑰 #在本地配置用戶名和郵箱,我的用戶名默認為jouzeyu git config --global user.name "jouzeyu" git config --global user.email "your email" 注意:如果用了 --global 選項,那么以后你所有的項目都會使用這里配置的用戶信息。如果要在某個特定的項目中使用其他名字或郵箱,只需在該項目下執行: git config user.name "xxx" git config user.email "xxx" OK,接下來我們獲取公鑰,請先查看你的用戶下的.ssh 文件夾中是否之前就含有公鑰和私鑰,我們需要尋找一對以 id_dsa 或 id_rsa 命名的文件,其中一個帶有 .pub 擴展名。 .pub 文件是你的公鑰,另一個則是私鑰。如果沒有請運行 ssh-keygen。 使用 cat ~/.ssh/id_rsa.pub 命令可以獲取公鑰,復制它,使用 vi 或者 vim 命令把它粘貼到我們之前創建的 authorized_keys 文件中,使用:wq 保存。 第四步:初始化倉庫 創建一個存放 git 倉庫的文件夾: mkdir /www/wwwroot/git cd /www/wwwroot/git 初始化倉庫: #初始化一個裸倉庫(強烈建議) git init --bare website.git #配置倉庫的權限,讓我們之前創建好的git用戶jouzeyu能讀寫 chown -R git:git website.git 這里必須注意,如果不給權限,后面的 git pull 將會報錯,原因是沒有權限寫入。關于裸倉庫和普通倉庫的區別簡單來說就是裸倉庫看不到項目文件,普通倉庫和你的項目目錄一樣,只是多了一個.git 文件夾。 第五步:生成項目倉庫 這個也是在服務器上進行的,同時說明一下 /www/wwwroot/ 是我的環境的根目錄。 #創建我服務器上的項目目錄test mkdir /www/wwwroot/test #克隆倉庫 git clone /www/wwwroot/git/website.git #設置權限 chown -R git website 注意:一定要注意我的路徑,git 倉庫是 /www/wwwroot/git, 項目倉庫是 /www/wwwroot/test。 第六步:克隆到本地 # 通過ip地址從配置好的線上倉庫拉取下來 git clone git@47.97.121.XXX:/www/wwwroot/git/website.git # 如果有配置域名的話也可以通過域名拉取 git clone git@www.XXX.XXX:/www/wwwroot/git/website.git 因為公鑰的原因,這里是不需要密碼的,如果成功你的電腦上會出現一個 website 的文件夾,如果報錯請檢查后再進行下面的操作。 第七步:測試上傳(git pull) # 打開剛才克隆下來的本地倉庫 cd website # 創建README.md文件 touch README.md git add . git commit -m"創建README.md文件" git push 不出意外已經正常上傳了,如果報錯請檢查權限,上文提到過,如果還不行可以在下方評論。 第八步:添加鉤子 終于到重頭戲了,寫的比較細,所以比較麻煩一些。回到我們線上的服務器,下面的是在線上操作的: #切換到這個目錄 cd /www/wwwroot/git/website.git/hooks # 生成post-receive文件 touch post-receive # 使用vim編輯 vim post-receive 在 post-receive 文件里面粘貼: #!/bin/sh # 打印輸出 echo '======上傳代碼到服務器======' # 打開線上項目文件夾 cd /www/wwwroot/test/website # 這個很重要,如果不取消的話將不能在cd的路徑上進行git操作 unset GIT_DIR git pull origin master # 自動編譯vue項目,如有需要請去掉前面的#號 # npm run build # 自動更新composer(我暫時沒試過) # composer update echo $(date) >> hook.log echo '======代碼更新完成======' 保存后給 post-receive 文件加上運行權限: chmod +x post-receive 最后一步 在本地修改部分內容,然后提交推送 git push,可以看到我們已經實現了自動化部署。 git 本作品采用《CC 協議》,轉載必須注明作者和本文鏈接 空舟湖上~ ?????——Jouzeyu ———————————————— 原文作者:Jouzeyu 轉自鏈接:https://learnku.com/articles/33689 版權聲明:著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請保留以上作者信息和原文鏈接。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看