您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何搭建git服務器管理網站”,在日常操作中,相信很多人在如何搭建git服務器管理網站問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何搭建git服務器管理網站”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
拓撲是這樣的:
網站服務器WS,就是你看到的本站的服務器啦。WS上我們主要需要做的是git服務器配置;
開發服務器DS,就是找的其他的服務器。DS上主要做的是配置git本地環境;
本地機PC,就是寫代碼的電腦了。
也就是說,預想的正確操作是:PC用PhpStorm開發代碼,用自帶的ssh提交功能提交到開發服務器上,DS提供web預覽,及時地預覽效果,當效果穩定后,使用git提交到網站服務器,就完成了功能迭代。同時git還能夠做版本控制,想想都有點小激動呢~有關如何搭建LNMP環境、如何配置PhpStorm的ssh,百度一下會出來很多資料,也可以評論和郵件我,這里不多介紹。
相關的版本一覽:
機器 | 軟件 | 版本 |
---|---|---|
WS/DS | 操作系統 | Debian 8.2 |
WS/DS | git | 2.1.4 |
這里的源是163提供的給Debian 8(Jessie)的源,你可以自己去尋找適合自己版本的163源、清華大學鏡像站源等等。
vi /etc/apt/sources.list
加入:
deb http://mirrors.163.com/debian/ jessie main non-free contrib deb http://mirrors.163.com/debian/ jessie-updates main non-free contrib deb http://mirrors.163.com/debian/ jessie-backports main non-free contrib deb-src http://mirrors.163.com/debian/ jessie main non-free contrib deb-src http://mirrors.163.com/debian/ jessie-updates main non-free contrib deb-src http://mirrors.163.com/debian/ jessie-backports main non-free contrib deb http://mirrors.163.com/debian-security/ jessie/updates main non-free contrib deb-src http://mirrors.163.com/debian-security/ jessie/updates main non-free contrib
apt-get install git apt-get install sudo
adduser bwb
密碼一定要輸哦,這個密碼是登錄這個賬戶的密碼。
vi /etc/sudoers
添加:
bwb ALL=(ALL:ALL) ALL
并使用wq!
進行強制保存。
cd ~/.ssh ssh-keygen -t rsa
會提示輸入密碼,這個密碼是這個密鑰的密碼,推薦輸入哦(雖然不輸入也能成功)。如果沒有.ssh目錄的話,可以手動創建一個。
可以使用類似xftp4
這類ftp工具,把生成的id_rsa.pub
從DS拷貝到WS上。如果使用xftp4的話,注意通過菜單欄的工具
→選項
,勾選“顯示隱藏的文件”來看到.ssh這個隱藏目錄。
從root用戶進入(或者直接從bwb用戶進入):
su bwb sudo mkdir ~/.ssh sudo cd ~/.ssh sudo cat id_rsa.pub >> authorized_keys sudo service ssh restart
(1)如果沒有.ssh才創建.ssh
(2)這里的id_rsa.pub
注意填為你拷貝的文件路徑。
(3)配置好后,你可以在DS上通過:
touch test.txt scp -r test.txt bwb@xxx.xxx.xxx.xxx:/home/bwb
來觀察test.txt
有沒有拷貝到WS上的/home/bwb
目錄下。這里的xxx.xxx.xxx.xxx是WS的IP,當然你也可以填網址域名。
我們全程假設web工程的目錄為/home/testweb。
(1)進入目錄
cd /home/testweb
(2)初始化空倉庫
git init
會提示:
初始化空的 Git 版本庫于 /home/testweb/.git/
(3)修改config
vi .git/config
加入:
[receive] denyCurrentBranch = ignore
(4)修改hook
新建一個hook
vi .git/hooks/post-receive
加入:
#!/bin/sh GIT_WORK_TREE=/home/testweb git checkout -f
(5)加入README.md
touch README.md
(6)加入工程下的所有的文件到git
git add .
注意后面的點哦。
(7)提交到本地倉庫
git commit -m "Initial commit"
(1)安裝環境
和前面配置源、安裝git的操作一致,只需要這兩步就可以了。
(2)克隆項目:
git clone bwb@xxx.xxx.xxx.xxx:/home/testweb
會提示輸入密碼,這是之前設置的id_rsa的密碼。
(3)[ 可選 ] 創建robot.txt禁止爬取所有文件:
vi robot.txt
加入:
User-agent: * Disallow: /
(4)[ 可選 ] 創建不想被上傳的文件的規則:
vi .gitignore
加入:
#self /.gitignore #robot robot.txt
(5)測試是否成功
echo "123" >> README.md git add . git status git commit -m "test" git push
git status是在提交前查看一下要提交的有哪些東西,可以不用這條命令。
如果前面的成功了,基本就搭建完了。這里只是為了更安全限制bwb的權限,只能git,不能登錄,且不能用sudo提權了:
(1)修改shell權限
vi /etc/passwd
把:
bwb:x:1000:1000:,,,:/home/bwb:/bin/bash
改為:
bwb:x:1000:1000:,,,:/home/bwb:/usr/bin/git-shell
(2)修改sudo權限
vi /etc/sudoers
把之前添加的:
bwb ALL=(ALL:ALL) ALL
用#注釋掉:
#bwb ALL=(ALL:ALL) ALL
注意使用wq!
強制保存,恭喜你,搭建完成了~
因為如果不加的話,DS進行push就會報錯,大意是它不是個裸倉庫:
remote: error: refusing to update checked out branch: refs/heads/master remote: error: By default, updating the current branch in a non-bare repository remote: error: is denied, because it will make the index and work tree inconsistent remote: error: with what you pushed, and will require 'git reset --hard' to match remote: error: the work tree to HEAD. remote: error: remote: error: You can set 'receive.denyCurrentBranch' configuration variable to remote: error: 'ignore' or 'warn' in the remote repository to allow pushing into remote: error: its current branch; however, this is not recommended unless you remote: error: arranged to update its work tree to match what you pushed in some remote: error: other way. remote: error: remote: error: To squelch this message and still keep the default behaviour, set remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.
因為如果不加hook的話,DS進行push,WS是看不到結果的,因為沒有更新worktree。你用在WS上使用git status就能看出區別了,它一直停留在master分支上。解決方法是手動更新:
git reset --hard
但是這樣太麻煩了,所以加hook,加了的話,就會自動更新,hook的意思就是“if做了什么操作,then就去做什么操作”,它幫你完成了。
這是一個我研究了好久并且實踐過的問題,答案是,--bare不適合web代碼管理。
(1)外觀
首先來看一下 git init --bare
(以下簡稱bare)和git init
(以下簡稱init)的外觀區別:
init會創建一個.git的隱藏文件夾,內容有branches、config、description、HEAD、hooks、info、objects、refs;
bare不會創建.git文件夾,而是直接在當前文件夾下創建同樣的這些內容。
(2)功能
init可以在git服務器上執行git操作;
bare不能在git服務器上執行git操作,會報錯:This operation must be run in a work tree
(3)本質
init的本質是會創建工作目錄,而bare的本質是只記錄歷史信息,不維護工作目錄。
因此,init適合于web項目的維護,可以在WS上實時地看到更新后的完整的web項目文件。而bare適合于多人的項目維護,不需要在遠端倉庫看到更新后的工作目錄,只需要記錄每個人操作了些什么東西即可。如果用bare維護web項目,DS進行push后,WS是沒有任何反應的(當然會更新objects文件,只是其他文件沒有反應),并且不能在WS上執行任何git操作。所以應該使用init。
git add . //重新提交 .ignore文件 git rm -r --cached . //清空緩存 git add . //重新提交 所有文件 git commit -m "update .gitignore" git push
注意命令中的點。
userdel -r bwb
bwb為你不想創建的用戶。
提示:
Are you sure you want to continue connecting (yes/no)? Host key verification failed. fatal: Could not read from remote repository.
這是因為你輸入的是回車而不是“yes”,輸入yes即可。
跟著提示設置一下config即可:
git config --global user.email "you@example.com" git config --global user.name "Your Name"
它的實質是去修改.git/config
文件。
首先檢查你是否有那個文件的權限(比如它是root用戶才能訪問的文件夾),如果沒有請賦予權限:
chown -R bwb:bwb home/testweb
然后檢查是否把DS的id_rsa.pub的內容成功添加進WS的authorized_keys了。
最后非常可能的就是你配錯了用戶。比如你把DS的id_rsa.pub配到WS的root用戶的authorized_keys里去了,結果后面訪問的ssh又是bwb用戶,當然被拒絕了。
如果還不行,debian操作系統可以查看/var/log/auth.log
,其他操作系統可以查看/var/log/secure
,然后:
tail -n100 /var/log/auth.log|grep sshd
來觀察到底有沒有進行過連接、到底是哪個地方出了問題。
#忽略文件 test.txt #忽略根目錄下的文件 /test.txt #忽略指定目錄下的文件 /src/test.txt #忽略目錄 /test #忽略文件夾,但不忽略其中的某些文件 /test !/test/test.txt
robot.txt在線生成
簡書的robot.txt
愛奇藝的robot.txt
最簡單的配置:
User-agent: * 這里的*代表的所有的搜索引擎種類,*是一個通配符 Disallow: / 這里定義是禁止爬尋站點所有的內容
到此,關于“如何搭建git服務器管理網站”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。