shell腳本-lnmp一鍵部署

来源:https://www.cnblogs.com/xuxuxuxuxu/archive/2023/07/16/17558015.html
-Advertisement-
Play Games

# shell腳本-lnmp一鍵部署 創建文件lnmp.sh ``` vim lnmp.sh ``` ``` #!/bin/bash #描述:LNMP網站架構部署腳本 cat /dev/null echo "創建Nginx運行用戶" groupadd www useradd -g www www - ...


shell腳本-lnmp一鍵部署

創建文件lnmp.sh

vim lnmp.sh
#!/bin/bash
#描述:LNMP網站架構部署腳本
cat <<EOF
歡迎使用LNMP架構服務搭建
請將安裝包放入/opt目錄下
1.安裝nginx服務
2.安裝mysql
3.安裝php
4.一鍵安裝LNMP架構
EOF
read -p "請輸入你的選擇:" choice

function Nginx(){
echo    -e "\033[34m 2.安裝Nginx \033[0m"
echo    "安裝Nginx依賴包"
nginx_gz=nginx-1.9.5.tar.gz
nginx=nginx-1.9.5
cd /opt
yum install -y gcc gcc-c++ autoconf automake zlib zlib-devel openssl openssl-devel  pcre pcre-devel make automake   &>/dev/null
echo    "創建Nginx運行用戶"
groupadd www
useradd -g www www -s /sbin/nologin
tar xf $nginx_gz
cd $nginx
./configure --prefix=/usr/local/nginx --with-http_dav_module --with-http_stub_status_module --with-http_addition_module --with-http_sub_module --with-http_flv_module --with-http_mp4_module --with-pcre --with-http_ssl_module --with-http_gzip_static_module --user=www --group=www &>/dev/null
if [ $? -eq 0 ];then
    echo    "Nginx預編譯完成,開始安裝"
else
    echo    "Nginx預編譯失敗,請檢查相關依賴包是否安裝"
    exit 4
fi
make && make install &>/dev/null
# 添加系統服務
cat > /etc/systemd/system/nginx.service <<EOF
[Unit]
Description=Nginx HTTP Server
After=network.target

[Service]
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s stop
Restart=on-failure
Type=forking

[Install]
WantedBy=multi-user.target
EOF

chmod  755  /usr/lib/systemd/system/nginx.service
/usr/local/nginx/sbin/nginx
netstat -anput | grep nginx &>/dev/null
if [ $? -eq 0 ];then
    echo    "Nginx啟動成功"
else
    echo    "Nginx啟動失敗"
    exit 5
fi
}

function MySQL(){
echo    -e "\033[35m 3.安裝MySQL \033[0m"
cd /opt
boost_bz2=boost_1_59_0.tar.bz2
mysql_gz=mysql-5.7.26.tar.gz
mysql=mysql-5.7.26
echo    "卸載原有MySQL及相關依賴"
yum -y remove mysql* mariadb* &>/dev/null
echo    "創建MySQL運行用戶"
groupadd mysql
useradd -M -s /sbin/nologin -r -g mysql mysql
mkdir -p /data/mysql/{data,log}
chown -R mysql:mysql /data/mysql/
echo    "安裝MySQL依賴包"
yum install -y cmake make gcc gcc-c++ bison ncurses ncurses-devel bzip2 &>/dev/null
tar jxf $boost_bz2 -C /opt
tar xf $mysql_gz
cd $mysql
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql/data -DSYSCONFDIR=/etc -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/opt/boost_1_59_0 &>/dev/null
if [ $? -eq 0 ];then
    echo    "MySQL預編譯完成,正在安裝"
else
    echo    "MySQL預編譯失敗,請檢查依賴包是否全部安裝"
    exit 6
fi
make && make install &>/dev/null
chown -R mysql:mysql /usr/local/mysql/
cat >>/etc/my.cnf<< eof
[mysqld]
basedir=/usr/local/mysql
datadir=/data/mysql/data
port=3306
socket=/usr/local/mysql/mysql.sock
symbolic-links=0
character-set-server=utf8
log-error=/data/mysql/log/mysqld.log
pid-file=/usr/local/mysql/mysqld.pid
eof
cp support-files/mysql.server /etc/init.d/mysql.server
chmod +x /etc/init.d/mysql.server
/usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/data
/etc/init.d/mysql.server start
netstat -anplt | grep mysql
if [ $? -eq 0 ];then
    echo    "MySQL啟動成功"
else
    echo    "MySQL啟動失敗"
    exit 7
fi
ln -s /usr/local/mysql/bin/* /usr/local/bin/
}

function Php(){
echo    -e "\033[36m 4.安裝PHP \033[0m"
libmcrypt_gz=libmcrypt-2.5.8.tar.gz
libmcrypt=libmcrypt-2.5.8
php_gz=php-5.6.40.tar.gz
php=php-5.6.40
cd /opt
echo    "安裝PHP依賴包"
yum -y install gcc autoconf  freetype gd libpng libpng-devel libjpeg libxml2 libxml2-devel zlib curl curl-devel freetype-devel libjpeg-devel bzip2 bzip2-devel openssl openssl-devel
tar xf $libmcrypt_gz
cd $libmcrypt
./configure --prefix=/usr/local/libmcrypt && make && make install &>/dev/null
cd /opt
tar xf $php_gz
cd $php
./configure --prefix=/usr/local/php5.6 --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --enable-mbstring --with-curl --with-gd --enable-fpm --with-config-file-path --with-openssl --enable-fpm --enable-sockets  --enable-sysvshm --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml  --with-mhash  --with-mcrypt=/usr/local/libmcrypt --with-config-file-path=/usr/local/php5.6/etc --with-config-file-scan-dir=/etc/php.d --with-bz2  &>/dev/null
make && make install &>/dev/null
cp php.ini-production /usr/local/php5.6/php.ini
cp /usr/local/php5.6/etc/php-fpm.conf.default /usr/local/php5.6/etc/php-fpm.conf
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
chmod +x /etc/init.d/php-fpm
/etc/init.d/php-fpm start
netstat -anput | grep php-fpm
if [ $? -eq 0 ];then
    echo    "PHP啟動成功"
else
    echo    "PHP啟動失敗"
    exit 8
fi
}

function conf(){ 
echo    -e "\033[33m 5.LNMP架構配置 \033[0m"
echo    "修改Nginx配置文件"
rm -rf /usr/local/nginx/conf/nginx.conf
cat >> /usr/local/nginx/conf/nginx.conf << eof
user  www;
worker_processes  2;
error_log  logs/error.log;
pid        logs/nginx.pid;
events {
        use epoll;
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  logs/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
    #gzip  on;
    ferver {
m       listen       80;
        server_name  localhost;
        charset utf-8;
        location / {
            root   html;
            index  index.php index.html index.htm;
        }
        location ~ \.php$ {
            root  html;
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}
eof
cat >> /usr/local/nginx/html/index.php << eof
<?php
        phpinfo();
?>
eof
cat >> /usr/local/nginx/html/mysql.php << eof
<?php
$link=mysql_connect('127.0.0.1','lnmp','123456');
if ($link)echo "connection success......";
mysql_close();
?>
eof
echo    "在MySQL中創建測試用戶"
mysql -uroot -e "grant all on *.* to 'lnmp'@'%' identified by '123456';"
mysql -uroot -e "flush privileges;"
echo    "重啟服務(NML)"
/usr/local/nginx/sbin/nginx -s reload
/etc/init.d/mysql.server restart
/etc/init.d/php-fpm restart
cd /opt
}

#########################調用函數#####################
case $choice in
        1)
                Nginx
                ;;
        2)
                MySQL
                ;;
        3)
                Php
                ;;
        4)
                Nginx
                sleep 2
                MySQL
                sleep 2
                Php
                sleep 2
                conf
                ;;
        *)
                echo "請輸入正確選項"
esac

啟動lnmp.sh

bash lnmp.sh

查看網路狀態

[root@localhost init.d]# netstat -tunlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 127.0.0.1:9000          0.0.0.0:*               LISTEN      1394/php-fpm: maste 
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      924/nginx: master p 
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      918/sshd            
tcp6       0      0 :::3306                 :::*                    LISTEN      1356/mysqld         
tcp6       0      0 :::22                   :::*                    LISTEN      918/sshd            
udp        0      0 0.0.0.0:68              0.0.0.0:*                           718/dhclient        
udp        0      0 127.0.0.1:323           0.0.0.0:*                           661/chronyd         
udp6       0      0 ::1:323                 :::*                                661/chronyd   

測試一下


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第三方鏡像是在Docker Hub或其他容器註冊表上提供的預構建Docker容器鏡像。這些鏡像由個人或組織創建和維護,可以作為您容器化應用程式的起點。 ### 查找第三方鏡像 [**Docker Hub**](https://hub.docker.com/) 是最大和最受歡迎的容器鏡像註冊表,包含官 ...
  • ### 歡迎訪問我的GitHub > 這裡分類和彙總了欣宸的全部原創(含配套源碼):[https://github.com/zq2599/blog_demos](https://github.com/zq2599/blog_demos) ### 本篇概覽 - 本文是《Java擴展Nginx》系列的第 ...
  • # Scala基礎篇 ## 數據類型 下表中列出的數據類型都是對象,可以直接對它們調用方法。 | 數據類型 | 描述 | | | | | Byte | 8位有符號補碼整數。數值區間為 -128 到 127 | | Short | 16位有符號補碼整數。數值區間為 -32768 到 32767 | | ...
  • 在Revit自帶的導出功能中,我們可以知道,Revit可以導出如下格式文件: 他們分別對應的API在Document類下麵,主要包含以下方法 1 Export(String, String, MassGBXMLExportOptions) 從體量模型文檔中導出gbXML文件。 2 Export(St ...
  • 上次老周扯了有關主、從實體的話題,本篇咱們再挖一下,主、從實體之間建立的關係,跟咱們常用的一對一、一對多這些關係之間有什麼不同。 先看看咱們從學習資料庫開始就特熟悉的常用關係——多對多、一對一、一對多說起。數據實體之間會建立什麼樣的關係,並不是規則性的,而是要看數據的功能。比如你家養的狗狗和水果(你 ...
  • Redis是一個開源的、高性能的、基於記憶體的鍵值資料庫,它支持多種數據結構,如字元串、列表、集合、散列、有序集合等。其中,Redis的散列(Hash)結構是一個常用的結構,今天跟大家分享一個我的日常操作,如何使用Redis的散列(Hash)結構來緩存和查詢對象的屬性值,以及如何用Lambda表達式樹 ...
  • # 使用Back推送消息到你的iPhone # 前言 我的好友看了我的博客,給我提了個需求,讓我搞個網站通知,我開始以為就是評論回覆然後發送郵件通知。不過他告訴我網站通知是,當有人評論或者留言後,會通知到我這邊來,消息是實時通知的,他說用的是Back,不需要發郵件,然後發了個GitHub鏈接給我,我 ...
  • # .NET6使用RabbitMQ學習 [TOC] ## 前提 前段時間上班無事,上網衝浪看到了消息隊列RabbitMQ,就想著學習一下,網上看了點資料在嗶哩嗶哩上看的到codeman講的一個rabbitmq的視頻,就跟著仔細學習一下,敲一下代碼。視頻地址: [rabbitmq視頻](【【2021最 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...