最后的话
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
资料预览
给大家整理的视频资料:
给大家整理的电子书资料:
如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
输入 /[路径名]/[脚本名].sh 即可进行自动快速配置,过程中提示输入 (y/n) 输入 y 则进行下一步,这样分阶段确认的原因是为了确保能够看到上一个快速配置结果中可能的错误和提示。
完整脚本
#! /bin/bash
# Create By GF 2023-03-20 10:31
# ----------- Configure - httpd - 2.4.54 -----------
# Need Program: /opt/httpd-2.4.54
# #################################### Configure - httpd - 2.4.54 ####################################
# Function: 快速配置(Quick Configure) httpd-2.4.54
# ##################################################
function Quick\_Configure\_httpd\_2\_4\_54() {
if [[ -d "/opt/httpd-2.4.54" ]]; then
local USER\_NAME="None"
local ITEM\_NAME="None"
# ------------------------------------------
read -p "[Confirm] Quick Configure ( httpd-2.4.54 )? (y/n)>" VERIFY
if [[ "$VERIFY" != "y" ]]; then exit 1; fi
# ------------------------------------------
# 命令 adduser 一般是在 Unix 系统下创建用户所用到的 Perl 脚本命令。
# 使用 adduser 时, 创建用户的过程更像是一种人机对话, 系统会提示你输入各种信息, 然后会根据这些信息帮你创建新用户。
# adduser 选项释义:
# -c, --comment "COMMENT" 设置用户的备注信息。
# -d, --home HOME\_DIR 指定用户的主目录路径。
# -s, --shell SHELL 指定用户的默认 Shell。
# -g, --gid GROUP 将用户添加到指定的用户组。
# -p, --password PASSWORD 设置用户的密码 (加密)。
# -e, --expiredate EXPIRE\_DATE 设置用户的过期日期。
# -r, --system 创建一个系统用户 (不可登录)。
USER\_NAME=$(cat /etc/passwd | grep -o "^apache")
# ..........................................
if [[ -z "$USER\_NAME" && -f "/usr/sbin/adduser" ]]; then adduser apache --system --home /var/www; fi
# ..........................................
# 命令 useradd 一般是在 Linux 系统下创建用户所用到的 ELF 可执行程序命令。
# 使用 useradd 时, 如果后面不添加任何参数选项, 创建出来的用户将是默认 "三无" 用户: 无 Home Directory, 无密码, 无系统 Shell。
# useradd 选项释义:
# -g, --gid GROUP 新账户主组的名称或 ID。
# -M, --no-create-home 不创建用户的主目录。
# -s, --shell SHELL 指定用户的默认 Shell。
USER\_NAME=$(cat /etc/passwd | grep -o "^apache")
# ..........................................
if [[ -z "$USER\_NAME" && -f "/usr/sbin/useradd" ]]; then useradd apache -s /sbin/nologin -M; fi
# ..........................................
USER\_NAME=$(cat /etc/passwd | grep -o "^apache")
echo "Exists User: $USER\_NAME"
# ------------------------------------------
if [[ ! -d "/var/www" ]]; then mkdir /var/www; fi
# ------------------------------------------
# 编辑 Apache (httpd) 配置文件 httpd.conf, 将 User daemon 改为 User apache
sed -r -i "s/^User [a-zA-Z]\*/User apache/" /opt/httpd-2.4.54/conf/httpd.conf
# ..........................................
ITEM\_NAME=$(cat /opt/httpd-2.4.54/conf/httpd.conf | grep --regexp="^User [a-zA-Z]\*")
echo "Edit Item: User ...... -> $ITEM\_NAME"
# ------------------------------------------
# 编辑 Apache (httpd) 配置文件 httpd.conf, 将 Group daemon 改为 Group apache
sed -r -i "s/^Group [a-zA-Z]\*/Group apache/" /opt/httpd-2.4.54/conf/httpd.conf
# ..........................................
ITEM\_NAME=$(cat /opt/httpd-2.4.54/conf/httpd.conf | grep --regexp="^Group [a-zA-Z]\*")
echo "Edit Item: Group ...... -> $ITEM\_NAME"
# ------------------------------------------
# 编辑 Apache (httpd) 配置文件 httpd.conf, 将 DocumentRoot "/opt/httpd-2.4.54/htdocs" 改为 DocumentRoot "/var/www"
sed -r -i "s%^DocumentRoot \".\*\"%DocumentRoot \"/var/www\"%" /opt/httpd-2.4.54/conf/httpd.conf
# ..........................................
ITEM\_NAME=$(cat /opt/httpd-2.4.54/conf/httpd.conf | grep --regexp="^DocumentRoot \".\*\"")
echo "Edit Item: DocumentRoot \"......\" -> $ITEM\_NAME"
# ------------------------------------------
# 编辑 Apache (httpd) 配置文件 httpd.conf, 将 <Directory "/opt/httpd-2.4.54/htdocs"> 改为 <Directory "/var/www">
sed -r -i "s%^<Directory \".\*htdocs\">%<Directory \"/var/www\">%" /opt/httpd-2.4.54/conf/httpd.conf
# ..........................................
ITEM\_NAME=$(cat /opt/httpd-2.4.54/conf/httpd.conf | grep --regexp="^<Directory \".\*www\">")
echo "Edit Item: <Directory \"......htdocs\"> -> $ITEM\_NAME"
else
echo "[Caution] Program: ( /opt/httpd-2.4.54 ) Does Not Exists."
# ------------------------------------------
return 0
fi
}
function main() {
# --------- Configure - httpd - 2.4.54 ---------
Quick_Configure_httpd_2_4_54
}
main
总结
为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!
这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。
本份面试集锦涵盖了
- 174 道运维工程师面试题
- 128道k8s面试题
- 108道shell脚本面试题
- 200道Linux面试题
- 51道docker面试题
- 35道Jenkis面试题
- 78道MongoDB面试题
- 17道ansible面试题
- 60道dubbo面试题
- 53道kafka面试
- 18道mysql面试题
- 40道nginx面试题
- 77道redis面试题
- 28道zookeeper
总计 1000+ 道面试题, 内容 又全含金量又高
- 174道运维工程师面试题
1、什么是运维?
2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?
3、现在给你三百台服务器,你怎么对他们进行管理?
4、简述raid0 raid1raid5二种工作模式的工作原理及特点
5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?
6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?
7、Tomcat和Resin有什么区别,工作中你怎么选择?
8、什么是中间件?什么是jdk?
9、讲述一下Tomcat8005、8009、8080三个端口的含义?
10、什么叫CDN?
11、什么叫网站灰度发布?
12、简述DNS进行域名解析的过程?
13、RabbitMQ是什么东西?
14、讲一下Keepalived的工作原理?
15、讲述一下LVS三种模式的工作过程?
16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
17、如何重置mysql root密码?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
止,不再深入研究,那么很难做到真正的技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!