馬哥教育網絡班22期+第16周課程練習

1、源碼編譯安裝LNMP架構環境;

安裝開發包組
	yum groupinstall "Development Tools" "Server Platform Development" -y

	yum install -y pcre-devel zlib-devel

	yum install openssl openssl-devel -y

	groupadd -r -g 911 nginx
	useradd -r -g nginx -u 911 -s /sbin/nologin nginx
	mkdir -p /var/tmp/nginx/client
	cd /usr/local
	wget http://nginx.org/download/nginx-1.8.1.tar.gz
	tar -xf nginx-1.8.1.tar.gz 
	cd /usr/local/nginx-1.8.1/

	./configure \
	--prefix=$dst \
	--conf-path=/etc/nginx/nginx.conf \
	--user=nginx \
	--group=nginx \
	--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 \
	--with-http_ssl_module \
	--with-http_gzip_static_module \
	--with-debug \
	--with-http_stub_status_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/uwsg \
	--http-scgi-temp-path=/var/tmp/nginx/scgi \
	--with-pcre \
	--with-debug

	make
	make install

	vim /etc/nginx/nginx.conf          //編輯nginx配置安裝文件

	location / {
	            root   html;
	            index  index.php index.html index.htm;  //設置根目錄可識別index.php
	        }

	location ~ \.php$ {
	            root           html;
	            fastcgi_pass   127.0.0.1:9000;
	            fastcgi_index  index.php;
	            fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;     //設置使用fastcg協議的php文件根目錄
	            include        fastcgi_params;
	        }


	修改PATH環境變量,讓系統可以直接使用nginx的相關命令
	vim /etc/profile.d/nginx.sh
	export PATH=/usr/local/nginx/sbin:$PATH
	source /etc/profile.d/nginx.sh 

	nginx  啟動nginx

	yum install -y mariadb mariadb-server php-fpm php-mysql php-gd libjpeg* php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-bcmath php-mhash 

	systemctl start mariadb.service

	vim /etc/php-fpm.d/www.conf      //編輯php-fpm配置文件

	listen = 127.0.0.1:9000      //如不是監聽本地地址,可修改為需要監聽的地址
	listen.allowed_clients = 127.0.0.1   //本地訪問
	user = nginx
	group = nginx

	systemctl start php-fpm  //啟動 php-fpm

	vim /usr/local/nginx/html/index.php

	 測試頁面index.php示例如下:

	<?php

	$conn = mysql_connect('127.0.0.1','root','');
	if ($conn)
	        echo "ok";
	else
	        echo "Failure";

	phpinfo();
	?>

2、編寫一個腳本完成以下功能:

   (1)、一鍵搭建LNMP源碼編譯環境;

   (2)、可通過在腳本后面跟上一些參數來自定義安裝目錄等其他選項。

	# install run environment packages
	echo "install development tools and server platform develpment"
	yum groupinstall "Development Tools" "Server Platform Development" -y
	if [ $? -ne 0 ];then
		echo -e "\033[31m install development packages faild \033[0m" && exit
	else
		echo -e "\033[37m install development packages finished \033[0m"
	fi
	yum install -y pcre-devel zlib-devel openssl openssl-devel
	if [ $? -ne 0 ];then 
		echo -e "\033[31m install run environment packages faild\033[0m" && exit
	else 
		echo -e  "\033[37m install run environment packages finished\033[0m"
	fi 

	sleep 3s
	#install nginx
	echo -e "\033[37m install nginx\033[0m"
	groupadd -r -g 911 nginx
	useradd -r -g nginx -u 911 -s /sbin/nologin nginx

	dst=$1
	#dst=/usr/local/nginx
	#[ ! -d $dst ] && mkdir -p $dst
	mkdir -p /var/tmp/nginx/client

	cd /usr/local
	[ ! -f nginx-1.8.1.tar.gz ] && wget http://nginx.org/download/nginx-1.8.1.tar.gz
	tar -xf nginx-1.8.1.tar.gz 
	cd /usr/local/nginx-1.8.1/

	./configure \
	--prefix=$dst \
	--conf-path=/etc/nginx/nginx.conf \
	--user=nginx \
	--group=nginx \
	--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 \
	--with-http_ssl_module \
	--with-http_gzip_static_module \
	--with-debug \
	--with-http_stub_status_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/uwsg \
	--http-scgi-temp-path=/var/tmp/nginx/scgi \
	--with-pcre \
	--with-debug

	make
	make install
	if [ $? -ne 0 ];then
	        echo -e "\033[31m install nginx faild \033[0m" && exit
	else 
	        echo -e "\033[37m install nginx finished \033[0m"
	fi
	sleep 3s

	#install mariadb php-fpm
	echo -e "\033[37m install mariadb php-fpm \033[0m"

	yum install -y mariadb mariadb-server php-fpm php-mysql php-gd libjpeg* php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-bcmath php-mhash
	if [ $? -ne 0 ];then
	        echo -e "\033[31m install mariadb php-fpm faild \033[0m" && exit
	else
	        echo -e "\033[37m install mariadb php-fpm finished \033[0m"
	fi
	sleep 3s

	#config nginx
	echo -e "\033[37m config nginx \033[0m"
	sed -r -i 's/(^[[:space:]]+index ).*/\1index.php index.html index.htm;/g' /etc/nginx/nginx.conf
	sed -r -i '/pass the/,/}/s/(.*)#(.*)/\1\2/g' /etc/nginx/nginx.conf
	sed -r -i 's/(^[[:space:]]+)(pass the .*)/\1#\2/g' /etc/nginx/nginx.conf
	sed -r -i 's@(^[[:space:]]+fastcgi_param.*)/scripts(.*)@\1/usr/local/nginx/html\2@g' /etc/nginx/nginx.conf

	#config php-fpm
	echo -e "\033[37m config php-fpm \033[0m"
	sed -i 's/^user = apache/user = nginx/g'  /etc/php-fpm.d/www.conf
	sed -i 's/^group = apache/group = nginx/g'  /etc/php-fpm.d/www.conf

	#create php test page
	cd /usr/local/nginx/html
	#[ ! -f "/usr/local/nginx/html/index.php" ] && cat >>test.test<<EOF

	[ ! -f "/usr/local/nginx/html/index.php" ] && cat >>index.php<<EOF
	<?php

	\$conn = mysql_connect('127.0.0.1','root','');
	if (\$conn)
	        echo "ok";
	else
	        echo "Failure";

	phpinfo();
	?>
	EOF
	sleep 3s
	#start service
	echo -e "\033[37m start nginx service\033[37m"
	/usr/local/nginx/sbin/nginx
	echo -e "\033[37m start mariadb serivce\033[0m"
	systemctl start mariadb.service
	echo -e "\033[37m start php-fpm serivce \033[0m"
	systemctl start php-fpm.service
	

[root@test ~]# bash lnmp.sh /usr/local/nginx	

原創文章,作者:N22_上海_長清,如若轉載,請注明出處:http://www.www58058.com/65099

(0)
N22_上海_長清N22_上海_長清
上一篇 2017-01-03 11:05
下一篇 2017-01-03

相關推薦

  • 學習的第二周

    硬鏈接不能跨分區,硬鏈接不支持對目錄的創建, 硬鏈接的本質是一個文件N個節點  ls |xargs rm 解決參數太長 無法正常刪除的問題。   軟連接 依賴于原始文件 刪除就沒了軟連接可以跨分區,可以根據目錄創建軟連接,而且還可以針對文件夾 軟連接依賴于原始文件。原始文件刪了軟連接就打不開了  相對路徑一般相對當前工作目錄,但…

    Linux干貨 2017-05-30
  • ip命令詳解

      Linux中的ip命令功能強大,可以完成接口配置、路由管理等任務。   格式:ip [ OPTIONS ] OBJECT { COMMAND | help }   下面使用ip命令來完成一些常用的操作:     1、查看接口狀態       ip link show [設備名…

    Linux干貨 2016-01-14
  • sed和awk的用例及pam安全措施-第十五周

    總結sed和awk的詳細用法; sed用法 sed(Stream EDitor)是一款流編輯器,用來對文本進行過濾與替換操作。其原理是:通過文件或管道讀取文件內容,但是sed默認并不直接修改源文件,而是一次僅讀取文件的一行至模式空間(pattern space)根據sed指令進行編輯并輸出結果后清除模式空間,即所有的操作都是在模式空間中進行的。 語法格式 s…

    2017-06-05
  • 認識shell

    一、認識shell 什么是shell?shell為單詞外殼的意思。那么這是誰的外殼?我們知道一個系統中實際工作的是那些硬件,cpu、內存、磁盤等。我們如何調用這些硬件為我們工作?實際上,硬件是由內核kernel控制的。我們可以通過kernel控制硬件,但我們不能直接和內核kernel交流。我們需要一個外殼,這個外殼就是shell來溝通kernel。何為she…

    Linux干貨 2015-09-22
  • rpm與yum

    rpm包及yum 包查詢 rpm -q –query  搭配別的選項可用來包查詢 -a -f -p rpmfile:針對尚未安裝的程序包文件做查詢操作   -p 選項參數為文件名(一定要指定路徑) 例子: rpm -qpl /media/Packages/zsh-4.3.11-4.el6.centos.2.x86_64.rpm…

    Linux干貨 2016-08-24
  • 第三周作業

    1. 列出當前系統上所有已經登錄的用戶的用戶名,注意:同一個用戶登錄多次則顯示一次即可。 who | cut -d' ' -f1 | sort -u 2. 取出最后登錄當前系統的用戶的相關信息 grep  "$(who …

    Linux干貨 2016-12-19

評論列表(1條)

  • 馬哥教育
    馬哥教育 2017-01-04 16:04

    腳本寫的很好,一部分也做了條件判斷,我認為條件判斷還可以在多一點,如果第二次執行腳本會怎么樣?多加一些條件判斷吧

欧美性久久久久