Web服务基础五之yum安装配置LAMP环境+博客系统WordPress

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

Apache本身只支持静态网页,但目前的绝大多数网站都是动态Web站点,所以在实际应用中,Apache还必须得跟其它一些应用软件配合使用,只有这样才能构建一个高效可用的Web平台,目前使用较多的是LAMP平台(LAMP:Linux+Apace+MySQL+PHP)。在部署LAMP时,安装的一般顺序是Linux、Apache、MySQL、PHP,实际应用中,这些软件也大都是采用源码编译的方式来安装。

以下演示一个基本的LAMP环境搭建过程:

一、安装软件

1、RHEL6.3安装、配置:

  • 安装见之前的文章:RHEL6基础之四RHEL系统安装

  • 设置防火墙,开启mysql port:3306 apache port:80

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    [root@justin ~] # vim /etc/sysconfig/iptables
    # Firewall configuration written by system-config-firewall
    # Manual customization of this file is not recommended.
    *filter
    :INPUT ACCEPT [0:0]
    :FORWARD ACCEPT [0:0]
    :OUTPUT ACCEPT [0:0]
    -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
    -A INPUT -p icmp -j ACCEPT
    -A INPUT -i lo -j ACCEPT
    -A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
    -A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
    -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
    -A INPUT -j REJECT --reject-with icmp-host-prohibited
    -A FORWARD -j REJECT --reject-with icmp-host-prohibited
    COMMITTips
  • 设置SELinux:这里关闭SELinux,线上环境根据具体情况设定

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    [root@justin ~] # vim /etc/selinux/config
    # This file controls the state of SELinux on the system.
    # SELINUX= can take one of these three values:
    #     enforcing - SELinux security policy is enforced.
    #     permissive - SELinux prints warnings instead of enforcing.
    #     disabled - No SELinux policy is loaded.
    #SELINUX=enforcing
    SELINUX=disabled
    # SELINUXTYPE= can take one of these two values:
    #     targeted - Targeted processes are protected,
    #     mls - Multi Level Security protection.
    #SELINUXTYPE=targeted
    [root@justin ~] # reboot

    Tips:SELinux设置为disabled需要重启机器才能生效,设置为enforcing和permissive只需要重启服务即可。

2、安装Apache服务

1
2
[root@justin ~] # rpm -qa|grep httpd
[root@justin ~] # yum install httpd -y

   Tips:RHEL未注册是无法通过yum来安装,这里使用CentOS的yum,配置见之前的文章:RHEL6基础二十三之RHEL使用centos的Yum源

1
2
3
4
5
6
7
8
9
10
11
[root@justin ~] # /etc/init.d/httpd start
Starting httpd: httpd: apr_sockaddr_info_get() failed  for  justin
httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1  for  ServerName
                                                            [  OK  ]
[root@justin ~] # vim /etc/httpd/conf/httpd.conf
  276 ServerName localhost
[root@justin ~] # chkconfig --level 35 httpd on
[root@justin ~] # /etc/init.d/httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]
[root@justin ~] #

   Tips:Apache启动之后会提示错误:正在启动 httpd:httpd: Could not reliably determine the server's fully qualif domain name, using ::1 for ServerName ,修改配置文件276行为自己域名或者修改为localhost。

3、安装MySQL服务

  • 安装、启动

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    [root@justin ~] # yum install mysql mysql-server -y
    [root@justin ~] # /etc/init.d/mysqld start
    Initializing MySQL database:  Installing MySQL system tables...
    OK
    Filling help tables...
    OK
    To start mysqld at boot  time  you have to copy
    support-files /mysql .server to the right place  for  your system
    PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
    To  do  so, start the server,  then  issue the following commands:
    /usr/bin/mysqladmin  -u root password  'new-password'
    /usr/bin/mysqladmin  -u root -h justin password  'new-password'
    Alternatively you can run:
    /usr/bin/mysql_secure_installation
    which  will also give you the option of removing the  test
    databases and anonymous user created by default.  This is
    strongly recommended  for  production servers.
    See the manual  for  more  instructions.
    You can start the MySQL daemon with:
    cd  /usr  /usr/bin/mysqld_safe  &
    You can  test  the MySQL daemon with mysql- test -run.pl
    cd  /usr/mysql-test  ; perl mysql- test -run.pl
    Please report any problems with the  /usr/bin/mysqlbug  script!
                                                                [  OK  ]
    Starting mysqld:                                           [  OK  ]
    [root@justin ~] # chkconfig --level 35 mysqld on
    [root@justin ~] #
  • 拷贝配置文件、设置root账户密码(该root非系统账户root)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
[root@justin ~] # cp /usr/share/mysql/my-medium.cnf /etc/my.cnf
cp : overwrite ` /etc/my .cnf'? y
[root@justin ~] # mysql_secure_installation
NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL
       SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!
In order to log into MySQL to secure it, we'll need the current
password  for  the root user.  If you've just installed MySQL, and
you haven't  set  the root password yet, the password will be blank,
so you should just press enter here.
Enter current password  for  root (enter  for  none):
OK, successfully used password, moving on...
Setting the root password ensures that nobody can log into the MySQL
root user without the proper authorisation.
Set root password? [Y /n ] y    --设置root密码
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
  ... Success!
By default, a MySQL installation has an anonymous user, allowing anyone
to log into MySQL without having to have a user account created  for
them.  This is intended only  for  testing, and to  make  the installation
go a bit smoother.  You should remove them before moving into a
production environment.
Remove anonymous  users ? [Y /n ] y    --移除匿名用户
  ... Success!
Normally, root should only be allowed to connect from  'localhost' .  This
ensures that someone cannot guess at the root password from the network.
Disallow root login remotely? [Y /n ] y  --不允许远程通过root登陆
  ... Success!
By default, MySQL comes with a database named  'test'  that anyone can
access.  This is also intended only  for  testing, and should be removed
before moving into a production environment.
Remove  test  database and access to it? [Y /n ] y  --移除测试数据库
  - Dropping  test  database...
  ... Success!
  - Removing privileges on  test  database...
  ... Success!
Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.
Reload privilege tables now? [Y /n ] y    --重新加载特权表
  ... Success!
Cleaning up...
All  done !  If you've completed all of the above steps, your MySQL
installation should now be secure.
Thanks  for  using MySQL!
[root@justin ~] #

Tips:怎么修改数据库密码?遗忘数据库密码? 这里先不给出答案,先想下,稍后会通过微信平台给出,或者微信平台回复“mysql root密码”获取答案,如果无法获取回复可以通过回复“关键词”来获取相关问题关键词,然后再回复该关键词即可。

4、安装PHP

1
2
3
4
5
6
7
8
9
10
11
12
[root@justin ~] # yum install php php-mysql -y
Dependency Installed:
   php-cli.i686 0:5.3.3-27.el6_5      php-common.i686 0:5.3.3-27.el6_5      php-pdo.i686 0:5.3.3-27.el6_5 
Complete!
[root@justin ~] # vim /var/www/html/index.php
<?php
phpinfo();
?>
[root@justin ~] # /etc/init.d/httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]
[root@justin ~] #

浏览器里输入服务器IP地址就可以查看到php的信息

wKiom1Lfgyzy-bcgAARhnUc09GU028.jpg

Tips:apache默认的程序目录是/var/www/html 权限设置:chown apache.apache -R /var/www/html ;chmod 700 -R /var/www/html/ 至此,RHEL6.3安装配置LAMP服务器(Apache+PHP5+MySQL)完成,下面搭建博客系统wordpress


二、搭建Wordpress博客系统

一、下载上传软件包

先在下载Wordpress软件包解压wordpress包后使用WinSCP工具把wordpress-x.x.x-zh_CN\wordpress文件夹里面的所有文件以二进制方式上到/var/www/html/目录(上传前删除/var/www/html/下所有文件)wKioL1LfiRmT8thtAAPT2UfIj_Q233.jpg二、创建wordpress数据库

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@justin ~] # mysql -uroot -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection  id  is 5
Server version: 5.1.71-log Source distribution
Copyright (c) 2000, 2013, Oracle and /or  its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and /or  its
affiliates. Other names may be trademarks of their respective
owners.
Type  'help;'  or  '\h'  for  help. Type  '\c'  to  clear  the current input statement.
mysql> create database wordpress;
Query OK, 1 row affected (0.00 sec)
mysql>  exit
Bye
[root@justin ~] #

三、安装wordpress

wKiom1LfjO-hw0JGAAGcYz-2LoI248.jpg点击【创建配置文件】→【现在就开始】进入以下界面,根据实际情况填写,以下为我的信息

wKioL1LfjX-iv-ytAAFMRtiWK88444.jpg填写完后点击【提交】→【进行安装】出现以下界面,根据实际情况填写,以下为我的信息wKioL1LfjhHTcAv7AAI3ETbMDdI286.jpg

填写完毕点击【安装wordpress】→点击【登陆】→输入帐号信息后进入博客管理界面

wKiom1LfjxTj6z10AANyfzNdgCw135.jpg




本文转自 justin_peng 51CTO博客,原文链接:http://blog.51cto.com/ityunwei2017/1353901,如需转载请自行联系原作者

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
29天前
|
存储 消息中间件 缓存
构建互联网高性能WEB系统经验总结
如何构建一个优秀的高性能、高可靠的应用系统对每一个开发者至关重要
27 2
|
1月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
40 2
|
1月前
|
存储 消息中间件 缓存
构建互联网高性能WEB系统经验总结
构建互联网高性能WEB系统经验总结
66 16
|
2月前
|
机器学习/深度学习 数据处理 数据库
基于Django的深度学习视频分类Web系统
基于Django的深度学习视频分类Web系统
66 4
基于Django的深度学习视频分类Web系统
|
1月前
|
负载均衡 监控 算法
论负载均衡技术在Web系统中的应用
【11月更文挑战第4天】在当今高并发的互联网环境中,负载均衡技术已经成为提升Web系统性能不可或缺的一环。通过有效地将请求分发到多个服务器上,负载均衡不仅能够提高系统的响应速度和处理能力,还能增强系统的可扩展性和稳定性。本文将结合我参与的一个实际软件项目,从项目概述、负载均衡算法原理以及实际应用三个方面,深入探讨负载均衡技术在Web系统中的应用。
93 2
|
2月前
|
机器学习/深度学习 监控 数据挖掘
基于Django和百度飞桨模型的情感识别Web系统
基于Django和百度飞桨模型的情感识别Web系统
47 5
|
2月前
|
域名解析 安全 网络安全
阿里云服务器WordPress环境上安装SSL证书
阿里云服务器WordPress环境上安装SSL证书
|
3月前
|
SQL 安全 数据库
Web安全漏洞专项靶场—SQL注入—docker环境—sqli-labs靶场—详细通关指南
Web安全漏洞专项靶场—SQL注入—docker环境—sqli-labs靶场—详细通关指南
650 1
|
3月前
|
网络协议 Windows
[收藏]优化基于Win 2000系统的Web服务器性能
[收藏]优化基于Win 2000系统的Web服务器性能
|
4月前
|
C# 数据可视化 开发者
WPF开发者福音:深度解析OxyPlot与LiveCharts图表库,轻松实现数据可视化不再是难题!
【8月更文挑战第31天】在WPF应用中,数据可视化对提升用户体验至关重要。本文介绍并演示了两种流行图表库OxyPlot和LiveCharts的集成与使用方法。OxyPlot是一款适用于.NET应用的开源图表库,提供多种图表类型,易于集成。LiveCharts则以其丰富的图表类型和动画效果,特别适合实时数据展示。通过具体代码示例,本文展示了如何利用这两种图表库创建折线图和柱状图,并详细说明了安装和配置步骤。希望本文能帮助开发者在WPF应用中轻松实现高效、美观的数据可视化。
250 0