1、请描述一次完整的http请求处理过程;
(1) 建立或处理连接:接收请求或拒绝请求 (2) 接收请求: 接收来自于网络的请求报文中对某资源的一次请求的过程; 持久连接:接收到请求不会断开这个请求 非持久连接:一个连接请求断开一次 并发访问响应模型(Web I/O): 单进程I/O结构:启动一个进程处理用户请求,而且一次只处理一个;多个请求被串行响应; 多进程I/O结构:并行启动多个进程,每个进程响应一个请求; 10000个进程--->服务器只能响应1000--->处理之后再响应 复用I/O结构:一个进程响应n个请求; 能够处理多路IO的连接器,一个进程响应多个用户请求 多线程模型:一个进程生成N个线程,每个线程响应一个用户请求; 事件驱动:event-driven 在服务器内部基于事件回调的机制,连接IO的追踪。 来完成客户端请求。 复用的多进程I/O结构:启动多个(m)进程,每个进程响应n个请求; (3) 处理请求:对请求报文进行解析,并获取请求的资源及请求方法等相关信息 元数据:请求报文首部 <method> <URL> <VERSION> Host: www.magedu.com 请求的主机名称 Connection:连接使用的方式 (4) 访问资源:获取请求报文中请求的资源 web服务器,即存放了web资源的服务器,负责向请求者提供对方请求的静态资源,或动态运行后生成的资源;这些资源放置于本地文件系统某路径下,此路径通常称为DocRoot /var/www/html/ images/1.jpg http://www.magedu.com/images/1.jpg web服务器资源路径映射方式: (a) docroot:直接映射 (b) alias:路径别名 (c) 虚拟主机docroot (d) 用户家目录docroot (5) 构建响应报文 资源的MIME类型: 显式分类 魔法分类:自行扫描 协商分类 URL重定向: web服务构建的响应并非客户端请求的资源,而是资源另外一个访问路径; 重定向:永久重定向、临时重定向 (6) 发送响应报文 TCP双向通道 (7) 记录日志
2、httpd所支持的处理模型有哪些,他们的分别使用于哪些环境。
prefork:多进程模型,每个进程响应一个请求; 一个主进程:负责生成n个子进程,子进程也称为工作进程,每个子进程处理一个用户请求;即便没有用户请求,也会预先生成多个空闲进程,随时等待请求到达;最大不会超过1024个;最小空闲多少,并发响应多少 prefork:最大不能超过1024个并发请求,高性能web服务器,这个差了一个数量级。10倍 c10k,这种模式很稳定,一个进程崩溃,不会影响到其他进程。---->问的性要求高的 worker:多线程模型,每个线程响应一个请求; 一个主进程:生成多个子进程,每个子进程负责生个多个线程,每个线程响应一个请求; m进程,n线程:m*n-----> 并发量稍微高点的 event:事件驱动模型,每个线程响应n个请求; 一个主进程:生成m个子进程,每个进程直接n个请求; m*n----->高并发--->
3、源码编译安装LAMP环境(基于wordpress程序),并写出详细的安装、配置、测试过程。
LAMP----->2.4 模块实现 yum groupinstall "Development Tools" "Server Platform Development"------>安装包组1、编译安装Apache httpd-2.4.9需要较新版本的apr和apr-util,因此需要事先对其进行升级 (1)、编译安装apr tar xf apr-1.5.0.tar.bz2cd apr-1.5.0./configure --prefix=/usr/local/apr make && make install (2)、编译安装apr-util tar xf apr-util-1.5.3.tar.bz2cd apr-util-1.5.3./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr make && make install (3)、编译安装httpd groupadd -r apache useradd -r -g apache apahce yum -y install pcre-devel ---->安装pcre-devel支持 tar xf httpd-2.4.9.tar.bz2cd httpd-2.4.9./configure --prefix=/usr/local/apache --sysconf=/etc/httpd24 --enable-so --enable-ssl --enable-cgi --enable-rewrite --withzlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util/ --enable-modules=most --enable-mpmsshared= all --with-mpm=event make && make install3、修改httpd的主配置文件,设置其Pid文件的路径 编辑vim /etc/httpd24/httpd.conf,添加如下行即可: PidFile "/var/run/httpd/httpd24.pid"提供httpd 运行脚本cd /etc/rc.d/init.d/ cp httpd httpd24 vim httpd24 apachectl=/usr/local/apache/bin/apachectl ---------------->改的 httpd=${HTTPD-/usr/local/apache/bin/httpd} ---->查看pid路径--->/usr/local/apache/logs/httpd.pid pidfile=${PIDFILE-/var/run/httpd/httpd24.pid}lockfile=${LOCKFILE-/var/lock/subsys/httpd24}chkconfig --add httpd24 chkconfig --list httpd24 httpd24 0:关闭 1:关闭 2:关闭 3:关闭 4:关闭 5:关闭 6:关闭 httpd -t ------------>检查语法hash -r --------------->清除缓存 vim /etc/profile.d/httpd.shexport PATH=/usr/local/apache/bin$PATH-------------->定义PATH读取 . /etc/profile.d/httpd.sh ------------->重读配置文件 编辑/etc/man.config,添加如下行即可 MANPATH /usr/local/apache/man 库文件和头文件的导出 输出apche的头文件至系统头文件路径/usr/include: 这可以通过简单的创建链接实现: ln -sv /usr/local/apache/include /usr/include/apache 输出mysql的库文件给系统库查找路径:echo '/usr/sbin/httpd' > /etc/ld.so.conf.d/httpd24.conf 而后让系统重新载入系统库: ldconfig service httpd24 start ss -tnl ---------------->查看80端口是否被监听到 ps aux | grep httpd----->查看工作模式 vim /etc/httpd24/httpd.conf ----------->配置文件 LoadModule deflate_module modules/mod_deflate.so----------->启用2、编译安装mariadb tar xf mariadb-5.5.36-linux-x86_64.tar.gz -C /usr/local准备数据目录 mkdir -pv /mydata/data------>创建数据存放目录 配置mariadb-----> groupadd -r -g 306 mysql useradd -r -g 306 -u 306 mysqlcd /usr/local/ ln -sv mariadb-5.5.36-linux-x86_64 mysqlcd /usr/local/mysql chown -R root:mysql ./* scripts/mysql_install_db --datadir=/mydata/data --user=mysql cp supper-files/mysql.server /etc/rc.d/init.d/mysqld chkconfig --add mysqld --->添加 chkconfig --list mysqld --->查看 mkdir /etc/mysql cp support-files/my-large.cnf /etc/mysql/my.cnf vim /etc/mysql/my.cnf 添加三个选项: datadir = /mydata/data innodb_file_per_table = on skip_name_resolve = on service mysqld start /usr/local/mysql/bin/mysql_secure_installation------------>安全初始化 mysql优化 编辑/etc/man.config,添加如下行即可: MANPATH /usr/local/mysql/man7、输出mysql的头文件至系统头文件路径/usr/include: 这可以通过简单的创建链接实现: ln -sv /usr/local/mysql/include /usr/include/mysql8、输出mysql的库文件给系统库查找路径:echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf 而后让系统重新载入系统库: ldconfig9、修改PATH环境变量,让系统可以直接使用mysql的相关命令。 vim /etc/profile.d/mysql.shexport PATH=/usr/local/mysql/bin:$PATH. /etc/profile.d/mysql.sh 安装php 解决依赖关系 yum -y groupinstall "Desktop Platform Development"yum -y install bzip2-devel libmcrypt-devel libxml2-devel2、编译安装php-php-5.4.26php-5.4.26.tar.bz2cd php-5.4.26./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --withmysqli=/ usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib -- with-libxml-dir=/usr --enable-xml --enable-sockets --with-apxs2=/usr/local/apache/bin/apxs --with-mcrypt --with-configfile- path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2 --enable-maintainer-zts make make testmake intall 为php提供配置文件: cp php.ini-production /etc/php.ini3、 编辑apache配置文件httpd.conf,以apache支持php# vim /etc/httpd24/httpd.conf1、添加如下二行 AddType application/x-httpd-php .php AddType application/x-httpd-php-source .phps2、定位至DirectoryIndex index.html 修改为: DirectoryIndex index.php index.html 启动httpd服务 测试页面index.php示例如下: <?php$link = mysql_connect('127.0.0.1','root','mageedu');if ($link)echo "Success...";elseecho "Failure..."; phpinfo(); mysql_close(); ?> 用 wordpress测试 unzip wordpress-4.5.3-zh_CN.zip cp -rf wordpress /usr/local/apache/htdocs/cd /usr/local/apache/htdocs/wordpress cp wp-config-sample.php wp-config.php vim wp-config.php defile ('DB_NAME', 'wpdb'); defile ('DB_USER', 'wpuser'); defile ('DB_PASSWORD', 'wppword'); 连上MySQL数据库 mysql -uroot -p GRANT ALL ON wpdb.* TO 'wpuser'@'localhost' IDENTIFIED BY 'wppword'; CREATE DATABASE wpdb; FLUSH PRIVILEGES; mysql -uwpuser -pwppword SHOW DATABASES; http://192.168.159.128/wordpress 访问---->安装
-
建立httpd服务器(基于编译的方式进行),要求:
-
提供两个基于名称的虚拟主机:
-
(a)www1.stuX.com,页面文件目录为/web/vhosts/www1;错误日志为/var/log/httpd/www1.err,访问日志为/var/log/httpd/www1.access;
-
(b)www2.stuX.com,页面文件目录为/web/vhosts/www2;错误日志为/var/log/httpd/www2.err,访问日志为/var/log/httpd/www2.access;
-
(c)为两个虚拟主机建立各自的主页文件index.html,内容分别为其对应的主机名;
-
(d)通过www1.stuX.com/server-status输出httpd工作状态相关信息,且只允许提供帐号密码才能访问(statustatus);
1、编译安装Apache httpd-2.4.9需要较新版本的apr和apr-util,因此需要事先对其进行升级 (1)、编译安装apr tar xf apr-1.5.0.tar.bz2 cd apr-1.5.0 ./configure --prefix=/usr/local/apr make && make install(2)、编译安装apr-util tar xf apr-util-1.5.3.tar.bz2 cd apr-util-1.5.3./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr make && make install(3)、编译安装httpd groupadd -r apache useradd -r -g apache apahce yum -y install pcre-devel ---->安装pcre-devel支持tar xf httpd-2.4.9.tar.bz2 cd httpd-2.4.9./configure --prefix=/usr/local/apache --sysconf=/etc/httpd24 --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util/ --enable-modules=most --enable-mpms-shared=all --with-mpm=event编译的时候报这个错误------------------------------------------------------------------------------------------------------------checking whether to enable mod_ssl… configure: error: mod_ssl has been requested but can not be built due to prerequisite failures yum install openssl-devel----->解决make && make install3、修改httpd的主配置文件,设置其Pid文件的路径 编辑vim /etc/httpd24/httpd.conf,添加如下行即可: PidFile "/var/run/httpd/httpd24.pid"提供httpd 运行脚本 cd /etc/rc.d/init.d/ cp httpd httpd24 vim httpd24 apachectl=/usr/local/apache/bin/apachectl ---------------->改的 httpd=${HTTPD-/usr/local/apache/bin/httpd} pidfile=${PIDFILE-/var/run/httpd/httpd24.pid} lockfile=${LOCKFILE-/var/lock/subsys/httpd24} chkconfig --add httpd24 chkconfig --list httpd24 httpd24 0:关闭 1:关闭 2:关闭 3:关闭 4:关闭 5:关闭 6:关闭 httpd -t ------------>检查语法 hash -r --------------->清除缓存 vim /etc/profile.d/httpd.sh export PATH=/usr/local/apache/bin$PATH-------------->定义PATH读取 . /etc/profile.d/httpd.sh ------------->重读配置文件 service httpd24 start ss -tnl ---------------->查看80端口是否被监听到 ps aux | grep httpd----->查看工作模式 vim /etc/httpd24/httpd.conf ----------->配置文件 LoadModule deflate_module modules/mod_deflate.so----------->启用 vim /etc/httpd24/httpd.conf #DocumentRoot "/usr/local/apache/htdocs" vim /etc/httpd24/extra/httpd-vhosts.conf <192.168.159.128 *:80> ServerAdmin webmaster@dummy-host.example.com DocumentRoot "/web/vhost/www1/" ServerName www1.stuX.com ServerAlias www.dummy-host.example.com ErrorLog "/var/log/httpd/www1.err" CustomLog "/var/log/httpd/www1.access" common <Directory "/web/vhost/www1"> AllowOverride None Options None Require all granted </Directory> </VirtualHost> <192.168.159.128 *:80> ServerAdmin webmaster@dummy-host2.example.com DocumentRoot "/web/vhosts/www2" ServerName www2.stuX.com ErrorLog "/var/log/httpd/www2.err" CustomLog "/var/log/httpd/www2.access" common <Directory "/web/vhost/www2"> AllowOverride None Options None Require all granted </Directory> </VirtualHost> mkdir -pv /web/vhost/{www1,www2} echo "www1.site" > /web/vhost/www1/index.html && echo "www2.site" > /web/vhost/www2/index.html [root@centos ~]# curl www1.stuX.com www1.site [root@centos ~]# curl www2.stuX.com www2.site vim /etc/httpd24/extra/httpd-vhosts.conf vim /etc/httpd24/extra/httpd-vhosts.conf <VirtualHost 192.168.159.128 *:80> DocumentRoot "/web/vhost/www1/"ServerName www1.stuX.com ErrorLog "/var/log/httpd/www1.err"CustomLog "/var/log/httpd/www1.access" common <Directory "/web/vhost/www1"> AllowOverride NoneOptions NoneRequire all granted </Directory> <Location /server-status> AuthType Basic AuthName "Only for Admin"AuthUserFile "/usr/local/apache/.htpasswd"Require valid-userSetHandler server-statusAllowOverride NoneOptions None</Location </VirtualHost> ./htpasswd -m -c /usr/local/apache/.htpasswd admin
原创文章,作者:N21_ Dominic,如若转载,请注明出处:http://www.178linux.com/48998
评论列表(1条)
统一回复下,看得出来很认真的在做练习了,写的也很好,即使一个没有经验的人也可以按照你的步骤搭建出来