隨筆-179  評(píng)論-666  文章-29  trackbacks-0
            2018年3月8日
          一、準(zhǔn)備 正式開(kāi)始前,編譯環(huán)境gcc、g++等開(kāi)發(fā)庫(kù)需要提前安裝。
          nginx依賴(lài)以下模塊: gzip模塊需要 zlib 庫(kù) rewrite模塊需要 pcre 庫(kù) ssl 功能需要openssl庫(kù)
          源碼目錄為:/usr/local/src
          1、安裝make yum -y install gcc automake autoconf libtool make
          2、安裝g++ yum install gcc gcc-c++
          3、安裝PCRE庫(kù) cd /usr/local/src wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.42.tar.gz tar -zxvf pcre-8.42.tar.gz cd pcre-8.42/ ./configure make && make install 出現(xiàn)如下報(bào)錯(cuò): make[2]: *** [install-libLTLIBRARIES] Error 1 make[2]: Leaving directory `/usr/local/src/pcre-8.42' make[1]: *** [install-am] Error 2 make[1]: Leaving directory `/usr/local/src/pcre-8.42' make: *** [install] Error 2 權(quán)限不夠,切換到root,重新make install即可。
          4、安裝zlib庫(kù) cd /usr/local/src wget http://zlib.net/zlib-1.2.11.tar.gz tar -zxvf zlib-1.2.11.tar.gz cd zlib-1.2.11/ ./configure make && make install
          5、安裝OpenSSL庫(kù) cd /usr/local/src wget http://www.openssl.org/source/openssl-1.1.0h.tar.gz tar -zxvf openssl-fips-2.0.16.tar.gz cd openssl-fips-2.0.16/ ./config make && make install 編譯安裝 Openssl 1.1.1 支持國(guó)密標(biāo)準(zhǔn) https://blog.51cto.com/1012682/2380553 6、創(chuàng)建用戶(hù)及用戶(hù)組 一般為了服務(wù)器安全,會(huì)指定一個(gè)普通用戶(hù)權(quán)限的賬號(hào)做為Nginx的運(yùn)行角色,這里使用www用戶(hù)做為Nginx工作進(jìn)程的用戶(hù)。后續(xù)安裝的PHP也以www用戶(hù)作為工作進(jìn)程用戶(hù)。 groupadd -r www useradd -r -g www www 二、NGINX 1、下載 cd /usr/local/src wget http://nginx.org/download/nginx-1.14.0.tar.gz tar –zxvf nginx-1.14.0.tar.gz cd nginx-1.14.0 2、配置 ./configure --prefix=/usr/local/nginx --sbin-path=/usr/local/nginx/sbin/nginx --conf-path=/usr/local/nginx/conf/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module --with-http_mp4_module --http-client-body-temp-path=/var/tmp/nginx/client/ --http-proxy-temp-path=/var/tmp/nginx/proxy/ --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi --http-scgi-temp-path=/var/tmp/nginx/scgi make && make install nginx編譯選項(xiàng)說(shuō)明: --prefix表示nginx要安裝到哪個(gè)路徑下,這里指定剛才新建好的/alidata/server目錄下的nginx-1.12.2; --sbin-path表示nginx的可執(zhí)行文件存放路徑 --conf-path表示nginx的主配置文件存放路徑,nginx允許使用不同的配置文件啟動(dòng),通過(guò)命令行中的-c選項(xiàng) --pid-path表示nginx.pid文件的存放路徑,將存儲(chǔ)的主進(jìn)程的進(jìn)程號(hào)。安裝完成后,可以隨時(shí)改變的文件名 , 在nginx.conf配置文件中使用 PID指令。默認(rèn)情況下,文件名 為prefix/logs/nginx.pid --error-log-path表示nginx的主錯(cuò)誤、警告、和診斷文件存放路徑 --http-log-path表示nginx的主請(qǐng)求的HTTP服務(wù)器的日志文件的存放路徑 --user表示nginx工作進(jìn)程的用戶(hù) --group表示nginx工作進(jìn)程的用戶(hù)組 --with-select_module或--without-select_module表示啟用或禁用構(gòu)建一個(gè)模塊來(lái)允許服務(wù)器使用select()方法 --with-poll_module或--without-poll_module表示啟用或禁用構(gòu)建一個(gè)模塊來(lái)允許服務(wù)器使用poll()方法 --with-http_ssl_module表示使用https協(xié)議模塊。默認(rèn)情況下,該模塊沒(méi)有被構(gòu)建。建立并運(yùn)行此模塊的OpenSSL庫(kù)是必需的 --with-pcre表示pcre的源碼路徑,因?yàn)榻鈮汉蟮膒cre是放在root目錄下的,所以是/root/pcre-8.41; --with-zlib表示zlib的源碼路徑,這里因?yàn)榻鈮汉蟮膠lib是放在root目錄下的,所以是/root/zlib-1.2.11 --with-openssl表示openssl庫(kù)的源碼路徑 配置OK: Configuration summary + using PCRE library: /usr/local/src/pcre-8.42 + using OpenSSL library: /usr/local/src/openssl-1.1.0h + using zlib library: /usr/local/src/zlib-1.2.11 nginx path prefix: "/usr/local/nginx" nginx binary file: "/usr/local/nginx/sbin/nginx" nginx modules path: "/usr/local/nginx/modules" nginx configuration prefix: "/usr/local/nginx" nginx configuration file: "/usr/local/nginx/nginx.conf" nginx pid file: "/usr/local/nginx/nginx.pid" nginx error log file: "/usr/local/nginx/logs/error.log" nginx http access log file: "/usr/local/nginx/logs/access.log" nginx http client request body temporary files: "/var/tmp/nginx/client/" nginx http proxy temporary files: "/var/tmp/nginx/proxy/" nginx http fastcgi temporary files: "/var/tmp/nginx/fcgi/" nginx http uwsgi temporary files: "/var/tmp/nginx/uwsgi" nginx http scgi temporary files: "/var/tmp/nginx/scgi" 3、安裝 make && make install 4、啟動(dòng) /usr/local/nginx/sbin/nginx 啟動(dòng)時(shí)報(bào)錯(cuò): nginx: [emerg] mkdir() "/var/tmp/nginx/client/" failed (2: No such file or directory) 手動(dòng)創(chuàng)建該目錄即可:mkdir -p /var/tmp/nginx/client 再次啟動(dòng),打開(kāi)瀏覽器訪(fǎng)問(wèn)此機(jī)器的IP,瀏覽器出現(xiàn)Welcome to nginx! 則表示 Nginx 已經(jīng)安裝并運(yùn)行成功。
          5、設(shè)置軟連接 ln -sf /usr/local/nginx/sbin/nginx /usr/sbin 這樣就可以直接執(zhí)行nginx來(lái)啟動(dòng)了。
          6、檢測(cè)nginx nginx -t 顯示: nginx: the configuration file /usr/local/nginx/nginx.conf syntax is ok nginx: configuration file /usr/local/nginx/nginx.conf test is successful 三、PHP 1、安裝PHP需要的常用庫(kù) yum -y install libmcrypt-devel mhash-devel libxslt-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel 2、下載 cd /usr/local/src wget http://cn2.php.net/downloads.php/php-7.2.5.tar.gz tar -zxvf php-7.2.5.tar.gz 3、配置 ./configure --prefix=/usr/local/php \ --with-mysql=mysqlnd \ --enable-mysqlnd \ --with-gd \ --enable-gd-jis-conv \ --enable-fpm 4、安裝 make && make install 安裝信息如下: Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20170718/ Installing PHP CLI binary: /usr/local/php/bin/ Installing PHP CLI man page: /usr/local/php/php/man/man1/ Installing PHP FPM binary: /usr/local/php/sbin/ Installing PHP FPM defconfig: /usr/local/php/etc/ Installing PHP FPM man page: /usr/local/php/php/man/man8/ Installing PHP FPM status page: /usr/local/php/php/php/fpm/ Installing phpdbg binary: /usr/local/php/bin/ Installing phpdbg man page: /usr/local/php/php/man/man1/ Installing PHP CGI binary: /usr/local/php/bin/ Installing PHP CGI man page: /usr/local/php/php/man/man1/ Installing build environment: /usr/local/php/lib/php/build/ Installing header files: /usr/local/php/include/php/ Installing helper programs: /usr/local/php/bin/ program: phpize program: php-config Installing man pages: /usr/local/php/php/man/man1/ page: phpize.1 page: php-config.1 Installing PEAR environment: /usr/local/php/lib/php/ [PEAR] Archive_Tar: upgrade to a newer version (1.4.3 is not newer than 1.4.3) [PEAR] Console_Getopt: upgrade to a newer version (1.4.1 is not newer than 1.4.1) [PEAR] Structures_Graph: upgrade to a newer version (1.1.1 is not newer than 1.1.1) [PEAR] XML_Util: upgrade to a newer version (1.4.2 is not newer than 1.4.2) [PEAR] PEAR: upgrade to a newer version (1.10.5 is not newer than 1.10.5) /usr/local/src/php-7.2.5/build/shtool install -c ext/phar/phar.phar /usr/local/php/bin ln -s -f phar.phar /usr/local/php/bin/phar Installing PDO headers: /usr/local/php/include/php/ext/pdo/ 5、添加環(huán)境變量 vim /etc/profile 在末尾加入 export PHP_HOME=/usr/local/php export PATH=/bin:/usr/bin:/usr/sbin:/sbin:$PATH:PHP_HOME/bin:$PHP_HOME/sbin 保存修改后,使用source命令重新加載配置文件: source /etc/profile 查看環(huán)境變量: echo $PATH 6、配置php-fpm cd /usr/local/php/etc cp php-fpm.conf.default php-fpm.conf cd php-fpm.d/ cp www.conf.default www.conf 使用vim命令對(duì)php-fpm.conf的內(nèi)容進(jìn)行如下修改: pid = /usr/local/php/var/run/php-fpm.pid 使用vim命令對(duì)php-fpm.conf的內(nèi)容進(jìn)行如下修改: user = www group = www 其他配置可根據(jù)需求進(jìn)行修改,比如pm.max_children(php-fpm 能啟動(dòng)的子進(jìn)程的最大數(shù)量)、pm.start_servers(php啟動(dòng)時(shí),開(kāi)啟的子進(jìn)程的數(shù)量)、pm.min_spare_servers(動(dòng)態(tài)方式空閑狀態(tài)下的最小php-fpm進(jìn)程數(shù)量)、pm.max_spare_servers(動(dòng)態(tài)方式空閑狀態(tài)下的最大php-fpm進(jìn)程數(shù)量)等。 7、啟動(dòng)php-fpm /usr/local/php/sbin/php-fpm 可以通過(guò)ps aux | grep php查看php進(jìn)程。 https://www.cnblogs.com/sunshineliulu/p/8991957.html 三、MySQL https://blog.csdn.net/weixin_33859844/article/details/90948191 https://www.cnblogs.com/yangchunlong/p/8477743.html
          posted @ 2019-08-13 17:37 Alpha 閱讀(408) | 評(píng)論 (0)編輯 收藏

          一、安裝git服務(wù)器所需軟件

          打開(kāi)終端輸入以下命令:

          ubuntu:~$ sudo apt-get install git-core openssh-server openssh-client
          git-core是git版本控制核心軟件

          安裝openssh-server和openssh-client是由于git需要通過(guò)ssh協(xié)議來(lái)在服務(wù)器與客戶(hù)端之間傳輸文件

          然后中間有個(gè)確認(rèn)操作,輸入Y后等待系統(tǒng)自動(dòng)從鏡像服務(wù)器中下載軟件安裝,安裝完后會(huì)回到用戶(hù)當(dāng)前目錄。如果

          安裝提示失敗,可能是因?yàn)橄到y(tǒng)軟件庫(kù)的索引文件太舊了,先更新一下就可以了,更新命令如下:

          ubuntu:~$ sudo apt-get update 

          更新完軟件庫(kù)索引后繼續(xù)執(zhí)行上面的安裝命令即可。

          安裝python的setuptools和gitosis,由于gitosis的安裝需要依賴(lài)于python的一些工具,所以我們需要先安裝python

          的setuptools。

          執(zhí)行下面的命令:

          ubuntu:~$ sudo apt-get install python-setuptools
          這個(gè)工具比較小,安裝也比較快,接下來(lái)準(zhǔn)備安裝gitosis,安裝gitosis之前需要初始化一下服務(wù)器的git用戶(hù)信息,這個(gè)隨便填。

          ubuntu:~$ git config --global user.name "myname"
          ubuntu:~$ git config --global user.email "******@gmail.com"

          初始化服務(wù)器用戶(hù)信息后,就可以安裝gitosis了,gitosis主要是用于給用戶(hù)授權(quán),設(shè)置權(quán)限也算是很方便的。

          可以通過(guò)以下命令獲取gitosis版本文件

          ubuntu:~$ git clone https://github.com/res0nat0r/gitosis.git
          注意:中間有兩個(gè)是數(shù)字零

          獲取gitosis文件后,進(jìn)入到文件目錄下面

          ubuntu:/tmp$ cd gitosis/

          接著使用python命令安裝目錄下的setup.py的python腳本進(jìn)行安裝

          ubuntu:/tmp/gitosis$ sudo python setup.py install

          到這里,整個(gè)安裝步驟就完成了,下面就開(kāi)始對(duì)git進(jìn)行一些基本的配置。

          二、創(chuàng)建git管理員賬戶(hù)、配置git

          創(chuàng)建一個(gè)賬戶(hù)(git)作為git服務(wù)器的管理員,可以管理其他用戶(hù)的項(xiàng)目權(quán)限。

          ubuntu:/tmp/gitosis$ sudo useradd -m git
          ubuntu:/tmp/gitosis$ sudo passwd git

          然后再/home目錄下創(chuàng)建一個(gè)項(xiàng)目倉(cāng)庫(kù)存儲(chǔ)點(diǎn),并設(shè)置只有g(shù)it用戶(hù)擁有所有權(quán)限,其他用戶(hù)沒(méi)有任何權(quán)限。

          ubuntu:/tmp/gitosis$ sudo mkdir /home/gitrepository
          ubuntu:/tmp/gitosis$ sudo chown git:git /home/gitrepository/
          ubuntu:/tmp/gitosis$ sudo chmod 700 /home/gitrepository/

          由于gitosis默認(rèn)狀態(tài)下會(huì)將倉(cāng)庫(kù)放在用戶(hù)的repositories目錄下,例如git用戶(hù)的倉(cāng)庫(kù)地址默認(rèn)在/home/git/repositories/目錄下,這里我們需要?jiǎng)?chuàng)建一個(gè)鏈接映射。讓他指向我們前面創(chuàng)建的專(zhuān)門(mén)用于存放項(xiàng)目的倉(cāng)庫(kù)目錄/home/gitrepository。

          ubuntu:/tmp/gitosis$ sudo ln -s /home/gitrepository /home/git/repositories

          這里我將在服務(wù)器端生成ssh公鑰,如果想在其他機(jī)器上管理也可以在其他機(jī)器上生成一個(gè)ssh的公鑰。

          ubuntu:/home/git$ ssh-keygen -t rsa

          這里會(huì)提示輸入密碼,我們不輸入直接回車(chē)即可。

          然后用剛生成公鑰id_rsa.pub來(lái)對(duì)gitosis進(jìn)行初始化。

          向gitosis添加公鑰并初始化:

          $ cp ~/.ssh/id_rsa.pub /tmp

          $ sudo -H -u gitadmin gitosis-init < /tmp/id_rsa.pub

          Ubuntu完美搭建Git服務(wù)器

          出現(xiàn)如上信息說(shuō)明gitosis已經(jīng)初始化成功。

          gitosis主要是通過(guò)gitosis-admin.git倉(cāng)庫(kù)來(lái)管理一些配置文件的,如用戶(hù)權(quán)限的管理。這里我們需要對(duì)其中的一個(gè)post-update文件添加可執(zhí)行的權(quán)限。

          ubuntu:/home/git$ sudo chmod 755 /home/gitrepository/gitosis-admin.git/hooks/post-update

          三、服務(wù)器上創(chuàng)建項(xiàng)目倉(cāng)庫(kù)

          使用git賬戶(hù)在服務(wù)器上創(chuàng)建一個(gè)目錄(mytestproject.git)并初始化成git項(xiàng)目倉(cāng)庫(kù)。

          ubuntu:/home/git$ su git
          $ cd /home/gitrepository
          $ mkdir mytestproject.git
          $ git init --bare mytestproject.git
          $ exit

          如果出現(xiàn)以下信息就說(shuō)明已經(jīng)成功創(chuàng)建了一個(gè)名為mytestproject.git的項(xiàng)目倉(cāng)庫(kù)了,新建的這個(gè)倉(cāng)庫(kù)暫時(shí)還是空的,不能被客戶(hù)端clone,還需要對(duì)gitosis進(jìn)行一些配置操作。

          四、使用gitosis管理用戶(hù)操作項(xiàng)目的權(quán)限

          首先需要在前面生成ssh公鑰(用來(lái)初始化gitosis)的機(jī)器上將gitosis-admin.git的倉(cāng)庫(kù)clone下來(lái)。

          在客戶(hù)端機(jī)器上新建一個(gè)目錄用于存放gitosis-admin.git倉(cāng)庫(kù)

          ubuntu:~$ mkdir gitadmin
          ubuntu:~$ cd gitadmin/
          ubuntu:~/gitadmin$ git clone git@192.168.1.106:gitosis-admin.git

          clone正確會(huì)顯示以下信息

          Ubuntu完美搭建Git服務(wù)器

          clone下來(lái)會(huì)有一個(gè)gitosis.conf的配置文件和一個(gè)keydir的目錄。gitosis.conf用于配置用戶(hù)的權(quán)限信息,keydir主要用戶(hù)存放ssh公鑰文件(一般以“用戶(hù)名.pub”命名,gitosis.conf配置文件中需使用相同用戶(hù)名),用于認(rèn)證請(qǐng)求的客戶(hù)端機(jī)器。

          現(xiàn)在讓需要授權(quán)的用戶(hù)使用前面的方式各自在其自己的機(jī)器上生成相應(yīng)的ssh公鑰文件,管理員把他們分別按用戶(hù)名命名好,復(fù)制到keydir目錄下。

          ubuntu:~$ cp /home/aaaaa/Desktop/zhangsan.pub /home/aaaaa/gitadmin/gitosis-admin/keydir/

          ubuntu:~$ cp /home/aaaaa/Desktop/lisi.pub /home/aaaaa/gitadmin/gitosis-admin/keydir/

          繼續(xù)編輯gitosis.conf文件

          [gitosis]

          [group gitosis-admin] 
          ####管理員組
          members = charn@ubuntu 
          ####管理員用戶(hù)名,需要在keydir目錄下找到相應(yīng)的.pub文件,多個(gè)可用空格隔開(kāi)(下同)
          writable = gitosis-admin####可寫(xiě)的項(xiàng)目倉(cāng)庫(kù)名,多個(gè)可用空格隔開(kāi)(下同)

          [group testwrite] 
          ####可寫(xiě)權(quán)限組
          members = zhangsan####組用戶(hù)
          writable = mytestproject####可寫(xiě)的項(xiàng)目倉(cāng)庫(kù)名

          [group
           testread] ####只讀權(quán)限組
          members =lisi####組用戶(hù)
          readonly= mytestproject####只讀項(xiàng)目倉(cāng)庫(kù)名

          因?yàn)檫@些配置的修改只是在本地修改的,還需要推送到服務(wù)器中才能生效。

          ubuntu:~/gitadmin/gitosis-admin$ git add .
          ubuntu:~/gitadmin/gitosis-admin$ git commit -am "add a user permission"
          ubuntu:~/gitadmin/gitosis-admin$ git push origin master

          推送成功會(huì)顯示下面提示信息

          Ubuntu完美搭建Git服務(wù)器

          又是后新增的用戶(hù)不能立即生效,這時(shí)候需要重新啟動(dòng)一下sshd服務(wù)

          ubuntu:~/gitadmin/gitosis-admin$ sudo /etc/init.d/ssh restart

          現(xiàn)在,服務(wù)端的git就已經(jīng)安裝和配置完成了,接下來(lái)就需要有權(quán)限的組成員在各自的機(jī)器上clone服務(wù)器上的相應(yīng)

          項(xiàng)目倉(cāng)庫(kù)進(jìn)行相應(yīng)的工作了。

          五、客戶(hù)端(windows)使用git

          下載安裝windows版本的git客戶(hù)端軟件,下載地址:http://msysgit.github.io/

          安裝完成后右鍵菜單會(huì)出現(xiàn)幾個(gè)git相關(guān)的菜單選項(xiàng),我們主要使用其中的git
           bash通過(guò)命令行來(lái)進(jìn)行操作。

          在本地新建一個(gè)目錄,使用git初始化這個(gè)目錄,然后再里面新建一個(gè)文本文件用于測(cè)試,最后關(guān)聯(lián)到git服務(wù)器倉(cāng)庫(kù)

          中的相關(guān)項(xiàng)目,最后上傳本地版本到服務(wù)器。

          $ mkdir testgit
          $ cd testgit
          $ git init
          $ echo "this is a test text file,will push to server" > hello.txt
          $ git add .
          $ git commit -am "init a base version,add a first file for push to server"
          $ git remote add origin git@serverip:mytestproject.git
          $ git push origin master

          這樣服務(wù)端就創(chuàng)建好了一個(gè)mytestproject.git的倉(cāng)庫(kù)的基礎(chǔ)版本了,現(xiàn)在其他組員只要從服務(wù)端進(jìn)行clone就可以了。

          window下面進(jìn)入到需要克隆的本地目錄下面右鍵選擇git bash選項(xiàng),輸入

          $ git clone git@serverip:mytestproject.git

          就可以把項(xiàng)目clone到本地倉(cāng)庫(kù)了。

          下面進(jìn)行簡(jiǎn)單的修改和提交操作

          $ cd mytestproject
          $ echo "this is another text file created by other" >another.txt
          $ git add .
          $ git commit -am "add a another file by other"
          $ git push origin master

          最后推送到服務(wù)器成功會(huì)顯示如下信息

          Ubuntu完美搭建Git服務(wù)器


          gitolite搭建git倉(cāng)庫(kù)(服務(wù)端+客戶(hù)端)

          http://blog.csdn.net/ChiChengIT/article/details/49863383

          posted @ 2018-03-13 15:35 Alpha 閱讀(1209) | 評(píng)論 (0)編輯 收藏
               摘要: Git 教程http://www.runoob.com/git/git-tutorial.htmlGit本地服務(wù)器搭建及使用Git是一款免費(fèi)、開(kāi)源的分布式版本控制系統(tǒng)。眾所周知的Github便是基于Git的開(kāi)源代碼庫(kù)以及版本控制系統(tǒng),由于其遠(yuǎn)程托管服務(wù)僅對(duì)開(kāi)源免費(fèi),所以搭建本地Git服務(wù)器也是個(gè)較好的選擇,本文將對(duì)此進(jìn)行詳細(xì)講解。(推薦一家提供私有源代碼免費(fèi)托管的網(wǎng)站:Bitbucket,目前支持...  閱讀全文
          posted @ 2018-03-08 10:44 Alpha 閱讀(3259) | 評(píng)論 (0)編輯 收藏
          主站蜘蛛池模板: 福鼎市| 南川市| 象州县| 海安县| 汾西县| 西和县| 乌兰察布市| 清流县| 双桥区| 大理市| 石屏县| 南木林县| 舟曲县| 贵州省| 通海县| 灵川县| 沂南县| 沂源县| 平湖市| 沁源县| 南投县| 惠州市| 桐庐县| 手游| 冕宁县| 江西省| 曲周县| 辉县市| 陈巴尔虎旗| 彭山县| 定南县| 金川县| 台湾省| 吉水县| 灵川县| 丹巴县| 剑阁县| 县级市| 洱源县| 陆河县| 邹城市|