》》》》》魏红斌带你学shell脚本《《《《《
更多shell脚本学习点击个人主页
作为一个资深程序猿,我将带领您从零开始,一步步踏上运维之旅,无论您是否拥有现成的服务器,都将学会如何轻松购买、部署,并通过编写及应用精心设计的Shell脚本,解决实际工作中遇到的问题。这些脚本不仅源自真实的业务场景,经历了反复实践与严格测试,确保了其简洁高效、易于理解且便于使用。更重要的是,我们将全程免费分享,并深度解析背后原理,助您深入理解并灵活运用,每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计,无偿提供并且提供相关解析过程,让读者能更深入了解相关内容。
无服务器的朋友们:
让我们先从选购并部署服务器开始。只需简单三步,即可拥有您的专属云服务器:
- 访问ECS官网:点击链接直达阿里云ECS网站:ECS选择网址。这是您获取高质量云服务器的第一站。
- 选择并购买:在琳琅满目的服务器配置中,挑选符合您需求的那一款,一键下单,完成支付。整个过程犹如在线购物般便捷。
- 进入ECS控制台:支付成功后,您将被引导至ECS管理控制台。在这里,您可以全面掌控您的服务器资源,后续的所有运维操作都将在此展开。
已有服务器的朋友们:
如果您已拥有ECS实例,那么请直接登录ECS管理控制台。在左侧导航栏中,依次选择“实例与镜像” > “实例”,确保您已定位到目标资源所在的资源组和地域。接下来,在实例列表中找到待连接的实例,点击操作列下的“远程连接”,选择“通过Workbench远程连接”并点击“立即登录”。
登录实例:
无论是新购还是已有服务器,接下来都需要进行实例登录。这里支持多种认证方式,以最常见的“密码认证”为例:
- 输入用户名(通常为
root
或ecs-user
)。 - 接着,输入登录密码。如果您忘记了密码,无需担忧,您可以在ECS实例详情页面查询,或者通过“更改密码”功能进行修改。
编写与运行Shell脚本:
成功登录后,您将看到一个熟悉的命令行界面——这就是您的运维主战场。现在,键入vim test.sh
,我们便进入了文本编辑模式,准备创建第一个Shell脚本。
按下键盘上的i
键,进入插入模式,此刻您可以自由地复制粘贴今天要学习的脚本代码,粘贴后按ecs
后,按:wq
保存脚本,可以用./ test.sh
或者sh test.sh
进行脚本执行。
今天我们要学习的脚本是(脚本内容直接复制粘贴即可):
#!/bin/bash
APR_URL=https://mirrors.tuna.tsinghua.edu.cn/apache/apr/
APR_FILE=apr-1.7.0
TAR=.tar.bz2
APR_UTIL_URL=https://mirrors.tuna.tsinghua.edu.cn/apache/apr/
APR_UTIL_FILE=apr-util-1.6.1
HTTPD_URL=https://mirrors.tuna.tsinghua.edu.cn/apache/httpd/
HTTPD_FILE=httpd-2.4.53
INSTALL_DIR=/data/httpd-2.4.53
CPUS=`lscpu | awk '/^CPU\(s\)/{print $2}'`
MPM=event
install_httpd(){
if [ `awk -F'"' '/^ID=/{print $2}' /etc/os-release` == "centos" ] &> /dev/null;then
yum -y install gcc make expat-devel pcre-devel openssl-devel wget bzip2
else
sudo apt update
sudo apt -y install gcc libapr1-dev libaprutil1-dev libpcre3 libpcre3-dev libssl-dev wget make
fi
cd /usr/local/src
wget $APR_URL$APR_FILE$TAR --no-check-certificate && wget $APR_UTIL_URL$APR_UTIL_FILE$TAR --no-check-certificate &&
wget $HTTPD_URL$HTTPD_FILE$TAR --no-check-certificate
tar xf $APR_FILE$TAR && tar xf $APR_UTIL_FILE$TAR && tar xf $HTTPD_FILE$TAR
mv $APR_FILE $HTTPD_FILE/srclib/apr
mv $APR_UTIL_FILE $HTTPD_FILE/srclib/apr-util
cd $HTTPD_FILE
./configure --prefix=$INSTALL_DIR --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --
with-included-apr --enable-modules=most --enable-mpms-shared=all --with-mpm=$MPM
make -j $CPUS && make install
useradd -s /sbin/nologin -r apache
sed -i 's/daemon/apache' $INSTALL_DIR/conf/httpd.conf
echo "PATH=/data/httpd-2.4.53/bin:$PATH" > /etc/profile.d/$HTTPD_FILE.sh
. /etc/profile.d/$HTTPD_FILE.sh
cat > /lib/systemd/system/httpd.service <<EOF
[Unit]
Description=The Apache HTTP Server
After=network.target remote-fs.target nss-lookup.target
Documentation=man:httpd(8)
Documentation=man:apachectl(8)
[Service]
Type=forking
ExecStart=${INSTALL_DIR}/bin/apachectl start
ExecReload=${INSTALL_DIR}/bin/apachectl graceful
ExecStop=${INSTALL_DIR}/bin/apachectl stop
killSignal=SIGCONT
PrivateTmp=true
[Install]
WantedBy=multi-user.target
EOF
systemctl daemon-reload
systemctl enable --now httpd
}
install_httpd
下面是脚本的关键步骤和逻辑的详细解析:
环境与变量设置
- 定义了APR、APR-util和httpd的下载URL、文件名及压缩格式。
- 设置了安装目录为
/data/httpd-2.4.53
。 - 通过
lscpu
命令获取CPU核心数,用于后续编译时的并行处理。 - 设定使用的MPM(多路处理模块)为
event
。
安装流程函数install_httpd
- 检测系统类型:根据
/etc/os-release
文件判断当前系统是否为CentOS。如果是CentOS,则使用yum
安装必要的依赖;否则,假设为Debian/Ubuntu系列,使用apt
安装相应的依赖。 - 下载源代码:进入
/usr/local/src
目录,从指定URL下载APR、APR-util和httpd的源代码压缩包,并关闭证书检查(--no-check-certificate
)。 - 解压文件:解压刚刚下载的三个压缩包。
- 移动文件:将APR和APR-util的源码移到httpd源码目录的相应位置,以供httpd编译时使用。
- 配置编译选项:在httpd源码目录执行
./configure
,配置安装路径、启用模块支持、SSL、CGI、重写等功能,并指定MPM模块。 - 编译与安装:使用
make
命令并行编译(利用所有CPU核心),然后安装到指定目录。 - 创建系统用户:为httpd服务创建一个非交互式的系统用户
apache
。 - 修改配置文件:将httpd.conf中的
daemon
用户改为apache
。 - 设置环境变量:在
/etc/profile.d/
下创建一个启动脚本,将httpd的bin目录添加到PATH环境变量中,并立即生效。 - 创建Systemd服务单元文件:在
/lib/systemd/system/
下创建httpd.service文件,定义了服务的启动、重启、停止命令等信息。 - Systemd操作:刷新Systemd守护进程配置,启用并立即启动httpd服务。
执行安装
脚本最后调用了install_httpd
函数,执行上述安装流程。
此脚本简化了手动安装Apache HTTP Server的过程,通过自动化下载、编译、安装以及配置,适合于希望快速部署或自动化部署httpd服务器的用户。需要注意的是,脚本中直接关闭证书检查可能带来安全风险,在生产环境中应谨慎处理。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用