lamp架构=Linux/unix/windows(操作系统)+apache/nginx……+mysql/pgsql +php/python/golang。
开发能力要自己努力。起码需要一些语言基础。
不懂代码何以精通?不堪官方源码何以做到熟悉?
nginx
nginx有官方网站:www.nginx.com
tar zxf nginx-1.18.0.tar.gz ##解压。解压之后里面有configure,表示他是开源的。
./configure --help ##查看一些参数
#--without开头的,表示这个默认就有,加这个选项就是把默认的去掉。但是如果--with表示默认没有这个功能,需要--with激活。
#--with-file-aio 支持文件的aio;--with-threads支持线程;--with-http_ssl_module支持https;--with-http_stub_status_module支持http的监控。
yum install gcc -y
yum install pcre-devel ##编译的时候是开发库,库文件,需要什么库,就在后面加上devel
yum install openssl-devel
./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-http_stub_status_module
#configure这个命令是为了在当前目录生成Makefile。刚才的参数全部写入了makefile中。上述的编译,出现什么问题就去解决即可。
make ##按照刚才makefile中的指令进行编译。会在当前目录生成符合当前系统的二进制程序。编译时间取决于你的系统性能和编译量。
make install ##安装,将你编译好的二进制程序在objs中,并且复制到了开始指定的文件中,包括配置文件,二进制程序,在sbin。
cd objs
cd /usr/local/nginx/sbin
du -h nginx ##检查发现这个目录很大,原因是开启了debug。后续要进行删除这个解压,重新解压,进行二次编译。
cd .. ##进入/usr/local/nginx
rm -rf * ##将他们全部删除
cd /mnt/nginx-1.18.0 ##返回到源码包里面,如果要进行二次编译,需要
make clean ##将objs删掉
#可以将这个解压出来的文件删掉,再重新去解压。这样环境也是干净的。
cd nginx-1.18.0 ##进入压缩包
vim auto/cc/gcc ##关闭debug,再次编译
./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-http_stub_status_module
make && make install
#一旦编译完成后,解压出来的源码就没用了,可以删除。转向/usr/local/nginx,这才是真正程序所安装的路径
cd /usr/local/nginx/
du -sh * ##大小不足1M,这就是关闭debug和不关闭debug的区别。
如何启动他?
#二进制环境在/usr/local/nginx/sbin中,但是这个环境并不在我们的PATH里面
echo $PATH ##查看环境变量
#可以将这个/usr/local/nginx/sbin加在环境变量中
cd
vim .bash_profile
source .bash_profile
which nginx
nginx ##在环境变量中,可以直接回车调用他。
yum install -y net-tools 用来查看操作系统中的端口
netstat -antlp ##查看端口,发现80端口打开。
#此时可以在浏览器中输入ip进行访问。welcome表示服务器就已经搭建好了。
cd /usr/local/nginx ##切换到此目录下查看,一旦程序启动了,会产生一些其他的目录。logs是记录日志的,html是默认发布目录;conf这个是配置
如何发布文件?
#nginx一旦开启了,不能重复开启,不然就会包错,因为端口已经被占用了。
nginx -s reload ##重载
nginx -s stop ##关闭 -s用于传参
netstat -antlp ##此时80端口就没了
上述指令在运行的时候,一定要在当前解压路径,不要随意切换。
##查看重定向
##编译的时候出现错误,按照提示进行安装解决。
##编译生成Makefile,刚才的参数全部写入了makefile中。
##make install将编译好的二进制程序放在objs中,并且复制到了开始指定的文件中,包括配置文件,二进制程序,在sbin。
##做二次编译,删除debug
##将这个/usr/local/nginx/sbin加在环境变量中
##出现此界面表示服务器已经搭建好
##当80端口打开的时候表示nginx已经开启,不要重复开启。可以如上述发布文件。
mysql
tar zxf mysql-boost-5.7.31.tar.gz ##解压源码包
yum install -y cmake ##mysql解压后需要cmake进行编译
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data cd -DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DWITH_BOOST=/mnt/mysql-5.7.31/boost/boost_1_59_0
#cmake会有一个cmakecache这个文件,在编译过程中,会把之前的进度缓存到这个文件中,如果编译出错,也会保存,就算后续解决了这个问题,他还是会加载这个文件,解决问题的步骤并不会保留。
#编译过程如果出错,需要下载别的软件的时候,必须首先删掉缓存信息,然后再下载重新编译。
rm -f CMakeCache.txt ##删掉缓存文件
yum install ncurses-devel -y
yum install -y gcc-c++
yum install -y bison
#上述是解决掉编译过程中出现的问题。出现error的时候,编译不成功,警告是可以成功的。
make ##进行编译。
make install ##安装,会向/usr/local/mysql目录中写入数据
cd /usr/local/mysql
du -sh ##1.9G
#做初始化,因为默认在/usr/local/mysql/下面没有data目录。
#脚本和主配置文件
cd support-files
vim mysql.server ##这是一个脚本
cp mysql.server /etc/init.d/mysqld
ll /etc/init.d/mysqld ##查看脚本是否有x权限,如果没有,必须添加。
vim /etc/my.cnf ##做主配置文件my
#有了脚本和文件就可以尝试去激活.
#/usr/local/mysql/bin,mysql的指令都在bin中,为了方便调用,可以放在环境变量中
cd
vim .bash_profile
source .bash_profile ##此时输入mysql并且按tab就会出现文件
#源码中没有指定用户
useradd -u 1000 -M -d /usr/local/mysql/data -s /sbin/nologin mysql
##M表示不要创建用户主目录,直接放到这个目录中。
mysqld --verbose --help | less ##使用帮助查看如何初始化
--initialize #正常
--initialize-insecure #管理员密码为空
mysqld --initialize --user=mysql ##设定在最后生成临时密码
ll /usr/local/mysql/data/ ##此时data下面就有了东西,是以mysql的身份
/etc/init.d/mysqld start ##启动
netstat -antlp | grep :3306 ##此时已经有了3306端口
#此时你的初始化只允许你登陆,不允许做任何的操作。
mysql_secure_installation ##需要做此操作使得可以对mysql进行操作
mysql -p ##进入mysql
#数据库最多的就是查询,对运维而言最多的就是数据的备份与恢复
##mysql的指令都在bin中,为了方便调用,可以放在环境变量中
php
yum install -y bzip2 ##解压此源码包需要安装解压工具
tar jxf php-7.4.12.tar.bz2
./configure --help | less ##查询解析方法
-prefix=/usr/local/php #路径
--with-config-file-path=/usr/local/php/etc #配置目录
--with-openssl-dir #加密
--with-snmp #简单网管协议,往往用于做监控
--enable-gd #图像
--with-zlib-dir #压缩
--with-curl
--with-pear #php的一个扩展
--enable-inline-optimization #优化
--enable-soap #动态编译
--enable-sockets
--enable-mbstring
--with-fpm-user=nginx #用户用户组为下面建立的nginx
--with-fpm-group=nginx
--with-fpm-systemd #启动脚本是systemd的方式
./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-mysqlnd --with-pdo-mysql --with-mysqli --with-openssl-dir --enable-gd --with-zlib-dir --with-curl --with-pear --enable-inline-optimization --enable-soap --enable-sockets --enable-mbstring --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --with-fpm-systemd
yum install -y systemd-devel.x86_64 ##安装开发包
#上述编译,出现什么包错,就去解决安装即可
oniguruma-6.8.2-1.el7.x86_64.rpm
oniguruma-devel-6.8.2-1.el7.x86_64.rpm
##解析过程中,需要安装这两个东西。
make
make install
useradd -M -d /usr/local/nginx -s /sbin/nologin nginx 新建一个普通用户
cd /usr/local/nginx
cd conf 进入主配置文件,通过主配置文件控制user