ECS 7天实践训练营-使用PolarDB和ECS搭建门户网站

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 因为未完全按教程的配置来,自己对用户名什么的进行了更改,出错较多,排查了不少时间,好在弄完了。

创建PolarDB数据库账号

1.利用url 通过浏览器的无痕模式登录到阿里云管理控制台
2.依次单击 产品与服务 > 云数据库PolarDB,进入 云数据库PolarDB管理控制台
3.单击集群列表 ,然后选择云产品资源地域。
4.创建数据库账号。
a.在 集群列表 页面,单击 集群ID ,进入 集群详情界面
b.单击 配置与管理 > 账号管理
c.点击创建账号 ,配置数据库账号账号类型(此处选择普通账号)和密码。
5.创建数据库。
a.单击数据库管理 ,然后单击 创建数据库
b.参考说明配置数据库信息,然后单击 创建 ,配置数据库(DB)名称支持字符集(默认设为utf8mb4)、授权账号(选择上一步创建的数据库账号)、账号类型备注说明
6.设置数据库白名单。
点击 集群白名单,然后在白名单界面将默认的白名单地址127.0.0.1更改为 0.0.0.0/0
注意事项:更改为0.0.0.0/0,不要少斜杠。

连接ECS服务器

前面提过很多次,不再提了。

安装LAMP环境

1.安装Apache服务及其扩展包。
yum -y install httpd httpd-manual mod_ssl mod_perl mod_auth_mysql
代码解释:
yum -y install是在线安装
后面接的是包名
之后将显示下列代码:

Dependency Installed:
  apr.x86_64 0:1.4.8-5.el7                                   apr-util.x86_64 0:1.5.2-6.el7
  gdbm-devel.x86_64 0:1.10-8.el7                             glibc-devel.x86_64 0:2.17-307.el7.1
  glibc-headers.x86_64 0:2.17-307.el7.1                      httpd-tools.x86_64 0:2.4.6-93.el7.centos
  kernel-headers.x86_64 0:3.10.0-1127.19.1.el7               libdb-devel.x86_64 0:5.3.21-25.el7
  mailcap.noarch 0:2.1.41-2.el7                              perl-BSD-Resource.x86_64 0:1.29.07-1.el7
  perl-Data-Dumper.x86_64 0:2.145-3.el7                      perl-ExtUtils-Install.noarch 0:1.58-295.el7
  perl-ExtUtils-MakeMaker.noarch 0:6.68-3.el7                perl-ExtUtils-Manifest.noarch 0:1.61-244.el7
  perl-ExtUtils-ParseXS.noarch 1:3.18-3.el7                  perl-Linux-Pid.x86_64 0:0.04-18.el7
  perl-Test-Harness.noarch 0:3.28-3.el7                      perl-devel.x86_64 4:5.16.3-295.el7
  pyparsing.noarch 0:1.5.6-9.el7                             systemtap-sdt-devel.x86_64 0:4.0-11.el7

Dependency Updated:
  glibc.x86_64 0:2.17-307.el7.1        glibc-common.x86_64 0:2.17-307.el7.1        nscd.x86_64 0:2.17-307.el7.1

2.安装PHP。
yum -y install php php-mysql gd php-gd gd-devel php-xml php-common php-mbstring php-ldap php-pear php-xmlrpc php-imap
代码解释:
依然是yum命令,作用同上
之后代码显示如下:

Dependency Updated:
  expat.x86_64 0:2.1.0-11.el7              libblkid.x86_64 0:2.23.2-63.el7      libmount.x86_64 0:2.23.2-63.el7
  libsmartcols.x86_64 0:2.23.2-63.el7      libuuid.x86_64 0:2.23.2-63.el7       util-linux.x86_64 0:2.23.2-63.el7

Complete!

3.下载并安装MySQL。

wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
yum -y install mysql57-community-release-el7-10.noarch.rpm
yum -y install mysql-community-server

代码解释:
wget 是一个从网络上自动下载文件的自由工具,wget url,即可从网站下载文件
注意事项:下载时间稍长,且三行代码并非一次性执行,需要按1次enter键。
运行成功后显示如下:

Dependency Updated:
  postfix.x86_64 2:2.10.1-9.el7

Replaced:
  mariadb-libs.x86_64 1:5.5.64-1.el7

Complete!

4.执行以下命令启动MySQL数据库。
systemctl start mysqld

搭建门户网站

1.安装Git。
yum -y install git
运行后代码显示如下:

Installed:
  git.x86_64 0:1.8.3.1-23.el7_8

Dependency Installed:
  perl-Error.noarch 1:0.17020-2.el7     perl-Git.noarch 0:1.8.3.1-23.el7_8     perl-TermReadKey.x86_64 0:2.30-20.el7

Complete!

2.下载PbootCMS源码文件。
cd ~ && git clone https://gitee.com/hnaoyun/PbootCMS.git
代码解释:
cd ~ 是跳转到当前用户的家目录,这里是root用户,cd ~ 相当于 cd /root
&&是为了让两个命令连续执行,只有前面命令执行成功,后面命令才继续执行
git clone可拷贝一个 Git 仓库到本地
成功后代码显示如下:

Cloning into 'PbootCMS'...
remote: Enumerating objects: 8821, done.
remote: Counting objects: 100% (8821/8821), done.
remote: Compressing objects: 100% (7749/7749), done.
remote: Total 8821 (delta 5044), reused 1596 (delta 579), pack-reused 0
Receiving objects: 100% (8821/8821), 31.85 MiB | 15.45 MiB/s, done.
Resolving deltas: 100% (5044/5044), done.

3.将安装包拷贝到Apache的wwwroot目录下。
cp -r PbootCMS/* /var/www/html/
代码解释:
cp:为英文全拼copy file,主要用于复制文件或目录。
-r:若给出的源文件是一个目录文件,此时将复制该目录下所有的子目录和文件。
4.执行以下命令修改站点根目录文件权限。
chmod -R a+w /var/www/html
5.向数据库中导入CMS的初始数据。

sql_file="/var/www/html/static/backup/sql/"$(ls /var/www/html/static/backup/sql/) &&
> mysql -hpc-地址 -u用户 -p密码 -Dmsj < $sql_file

当成功后会出现下面代码:

mysql: [Warning] Using a password on the command line interface can be insecure.

注意:[Warning] 不代表错误,这是mysql自带的,警示屏幕上直接输入mysql密码并显示是不安全的。
6.修改CMS系统数据库配置。

cat > /var/www/html/config/database.php << EOF
<?php
return array(
    'database' => array(
        'type' => 'mysqli', // 数据库连接驱动类型: mysqli,sqlite,pdo_mysql,pdo_sqlite
        'host' => '链接地址', // PolarDB数据库链接地址
        'user' => '用户名, // PolarDB数据库的用户名
        'passwd' => '密码', // PolarDB数据库的密码
        'port' => '3306', // 数据库端口
        'dbname' => '数据库名称' //数据库名称
    )
);
EOF

7.返回ECS控制台,开放80端口访问。
8.访问程序。
a.重启 Apache服务。
systemctl restart httpd
b.在浏览器地址栏输入云服务器的公网IP地址,进入门户网站首页和后台。
网站首页图片如下:
image.png
系统后台图片如下:
image.png

异常情况及处理:

1、导入CMS的初始数据时出现ERROR 1045 (28000): Access denied for user '用户名r'@'172.16.1.5' (using password: YES)
问题所在:用户名多打了r
解决方案:把r删去
2、导入CMS的初始数据时出现ERROR 1044 (42000): Access denied for user '用户'@'%' to database 'pbootcms'
问题所在:因为自己用的数据库名称并非教程上的,应当更改代码中的数据库名称
解决方案:将代码中的pbootcms改成自己的数据库名称.
3、修改CMS系统数据库配置时出现连接数据库服务器失败:Unknown MySQL server host 'pc-pc-pc-uf6r8tu7565twstxv.mysql.polardb.rds.aliyuncs.com' (2)
问题所在:数据库链接地址粘贴有误
解决方案:将修改配置代码中的数据库链接地址更改过来

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
存储 SQL 安全
应用案例|开源 PolarDB-X 在互联网安全场景的应用实践
中盾集团采用PolarDB-X云原生分布式数据库开源版本,有效解决了大数据量处理、复杂查询以及历史数据维护等难题,实现了业务的高效扩展与优化。
|
4月前
|
存储 Cloud Native 关系型数据库
PolarDB 高可用架构设计与实践
【8月更文第27天】 在现代互联网应用中,数据库作为核心的数据存储层,其稳定性和可靠性尤为重要。阿里云的 PolarDB 作为一款云原生的关系型数据库服务,提供了高可用、高性能和自动化的特性,适用于各种规模的应用。本文将详细介绍 PolarDB 的高可用架构设计,并探讨其实现数据安全性和业务连续性的关键技术。
116 0
|
17天前
|
SQL 人工智能 自然语言处理
PolarDB-PG AI最佳实践 1:基础能力实践
Polar_AI 是 PolarDB 数据库的 AI 扩展,集成了先进的人工智能模型和算法,使数据库能够执行机器学习和自然语言处理任务。它支持 PostgreSQL 及 Oracle 兼容版本,通过标准 SQL 轻松调用 AI 模型,具备简单易用、灵活可定制、无缝数据融合、数据安全和高性能等优势。用户可以通过 SQL 快速实现文本转向量、情感分类等功能,并能自定义扩展 AI 模型。
|
1月前
|
关系型数据库 Linux 分布式数据库
rpm安装polarDB-PG的实践
安装PolarDB for PostgreSQL的实践,需要帮助到有同样需要的小伙伴
|
1月前
|
NoSQL Cloud Native atlas
探索云原生数据库:MongoDB Atlas 的实践与思考
【10月更文挑战第21天】本文探讨了MongoDB Atlas的核心特性、实践应用及对云原生数据库未来的思考。MongoDB Atlas作为MongoDB的云原生版本,提供全球分布式、完全托管、弹性伸缩和安全合规等优势,支持快速部署、数据全球化、自动化运维和灵活定价。文章还讨论了云原生数据库的未来趋势,如架构灵活性、智能化运维和混合云支持,并分享了实施MongoDB Atlas的最佳实践。
|
2月前
|
NoSQL Cloud Native atlas
探索云原生数据库:MongoDB Atlas 的实践与思考
【10月更文挑战第20天】本文探讨了MongoDB Atlas的核心特性、实践应用及对未来云原生数据库的思考。MongoDB Atlas作为云原生数据库服务,具备全球分布、完全托管、弹性伸缩和安全合规等优势,支持快速部署、数据全球化、自动化运维和灵活定价。文章还讨论了实施MongoDB Atlas的最佳实践和职业心得,展望了云原生数据库的发展趋势。
|
5月前
|
存储 关系型数据库 MySQL
深度评测:PolarDB-X 开源分布式数据库的优势与实践
本文对阿里云开源分布式数据库 PolarDB-X 进行了详细评测。PolarDB-X 以其高性能、强可用性和出色的扩展能力在云原生数据库市场中脱颖而出。文章首先介绍了 PolarDB-X 的核心产品优势,包括金融级高可靠性、海量数据处理能力和高效的混合负载处理能力。随后,分析了其分布式架构设计,包括计算节点、存储节点、元数据服务和日志节点的功能分工。评测还涵盖了在 Windows 平台通过 WSL 环境部署 PolarDB-X 的过程,强调了环境准备和工具安装的关键步骤。使用体验方面,PolarDB-X 在处理分布式事务和实时分析时表现稳定,但在网络问题和性能瓶颈上仍需优化。最后,提出了改进建
7064 2
|
5月前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
5月前
|
SQL 弹性计算 关系型数据库
PolarDB产品使用问题之如何和ECS实例实现内网互通
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
弹性计算 JavaScript 数据可视化
下一篇
DataWorks