最近总当机,IT帮网站用了1天时间成功搬家

最近总当机,IT帮网站用了1天时间成功搬家

最近一两周,IT帮的会员、BA学员和AM学员时不时反馈网站打不开、敏捷个人APP登录不了,有时候又可以但是很慢,还有的时候电信能访问而联通网络访问不了。

这个体验可不好,于是前天想把站点和APP后台都挪一下窝,于是在腾讯买了个云主机,开始网站搬迁。

在过程中学习,以下是这次搬迁中的技术问题和解决记录,说不定对一些人有帮助,也可以给自己做个备份,以便之后再次搬迁时查看。

购买云主机,安装系统

在腾讯云选了配置,付钱就OK了。因为我没学过Linux啊,以前都是在window上干活,工作中服务器端我也不需要自己去做,我提出需求即可。所以云主机购买时我选择的是window系统,因为总觉得这样搬移我的工作量就可以少。

不过我不喜欢重复,所以想换成CentOS系统。从window切换到centos系统会更改系统盘大小之类的,要下工单由后台重新分配主机。没过多久给我重新分配安装了CentOS 6。通过腾讯云控制台登录,感觉网页操作有点慢,于是想着远程命令行操作。我的是Mac机,于是百度了“Mac CentOS 远程操作”,知道通过终端SSH就能访问,于是通过SSH进行了远程操作。

因为没学过linux,不熟悉命令行啊,于是想弄个图形桌面是不是更容易上手呢。于是网上查了一些如何安装图形界面。操作了几次,死机几次,重装了几次。后来想干脆从CentOS6重装到CentOS7.2,虽然网上有人说CentOS7可能会对熟悉的人有些不方便。不过我反正都不会,于是选择装最新版,所以自己重新安装了CentOS7系统。

从CentOS6切换到7很快,一下子就好了。我接着通过Mac终端ssh命令访问重装后的CentOS7,不过提示错了:
@    WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!     @
Host key verification failed.
 
这个问题的解决方法如下:
finder->前往—>前往文件夹,输入 /Users/sw/.ssh/known_hosts,将文件中与ip地址相关的信息全部删除,保存即可。
还可以这样搞定: ssh-keygen -R  [IP_ADDRESS]

这个问题搞定之后,通过SSH操作。因为我对linux的生疏,还是不习惯命令行,所以还是想要一个图形界面来远程操作,于是网上找如何安装系统桌面,又查找VNC怎么安装。按照不同文章所示进行操作,死机了几次,重装了几次。最后终于安装好了,不过最后发现基本也没有用到,因为我觉得得练习一下命令行操作,而且大部分教程也都是命令行的。

最近总当机,IT帮网站用了1天时间成功搬家

安装PHP环境

因为IT帮网站、敏捷个人APP后台都是基于PHP开发的,所以在搞定系统之后就开始时安装环境了。当然为了简单性,你也可以直接从服务市场获得做好的PHP环境镜像。不过我第一次弄这个,还是留给我自己吧。

上网搜索“CentoOS7 PHP环境”,出来很多相关文章,这个过程还是又折腾了一些时间。以下是正确操作的这一次的步骤:

卸载mariadb

CentOS7默认不用MySQL,而是mariadb了,虽说mariadb可以向后兼容MySQL,不过我还是想用MySQL,所以我先要卸载mariadb。

先列出所有被安装的rpm package

# rpm -qa | grep mariadb
mariadb-libs-5.5.50-1.el7_2.x86_64
mariadb-5.5.50-1.el7_2.x86_64
mariadb-server-5.5.50-1.el7_2.x86_64

不同版本返回结果可能不一样,按照返回版本号卸载上面返回的内容

# rpm -e mariadb-libs-5.5.50-1.el7_2.x86_64

安装MySQL

CentOS 7的yum源中貌似没有正常安装mysql时的mysql-sever文件,需要去官网上下载

 
# wget http://repo.mysql.com/mysql57-community-release-el7-10.noarch.rpm
# rpm -Uvh mysql57-community-release-el7-10.noarch.rpm
# yum install -y mysql-community-server

成功安装之后重启mysql服务

 
# service mysqld restart

为了加强安全性,MySQL5.7为root用户随机生成了一个密码,在error log中,关于error log的位置,如果安装的是RPM包,则默认是/var/log/mysqld.log。
只有启动过一次mysql才可以查看临时密码

grep 'temporary password' /var/log/mysqld.log(如果之前安装过MySQL则这里可能会有多个密码,用最后一个,注意这个密码输入时是可以粘贴的)
 最近总当机,IT帮网站用了1天时间成功搬家
 

这里的密码是YdsGaxOq>2n!

登陆并修改密码

使用默认的密码登陆

mysql -uroot -p(这是一个MySQL的以密码登录root用户的命令)

可以通过以下命令去设置密码:

 
# mysql -uroot
mysql> set password for 'root'@'localhost' = password('mypasswd');
mysql> exit

如何在CentOS中添加Swap

MySQL启动以下后发现自动关闭,查找日志发现:cannot allocate the memory for the buffer pool。通过 free -ml 看到swap是0,于是要添加swap文件。

1、使用dd命令创建一个swap交换文件

dd if=/dev/zero of=/home/swap bs=1024 count=1024000

这样就建立一个/home/swap的分区文件,大小为1G。

2、制作为swap格式文件:

mkswap /home/swap

3、再用swapon命令把这个文件分区挂载swap分区

/sbin/swapon /home/swap

我们用free -m命令看一下,发现已经有交换分区了。
最近总当机,IT帮网站用了1天时间成功搬家
但是重启系统后,swap分区又变成0了。

4、为防止重启后swap分区变成0,要修改/etc/fstab文件

vi /etc/fstab

在文件末尾(最后一行)加上

/home/swap swap swap default 0 0

这样就算重启系统,swap分区还是有值。

删除swap交换文件

1、先停止swap分区

/sbin/swapoff /home/swap

2、删除swap分区文件

rm -rf /home/swap

3、删除自动挂载配置命令

vi /etc/fstab

这行删除

/home/swap swap swap default 0 0

这样就能把手动增加的交换文件删除了。
注意:
1、增加删除swap的操作只能使用root用户来操作。
2、装系统时分配的swap分区貌似删除不了。
3、swap分区一般为内存的2倍,但最大不超过2G

安装Apache

yum install httpd #根据提示,输入Y安装即可成功安装

  • systemctl start httpd.service #启动apache
  • systemctl stop httpd.service #停止apache
  • systemctl restart httpd.service #重启apache
  • systemctl enable httpd.service #设置apache开机启动

在客户端浏览器中打开服务器IP地址,会出现下面的界面,说明apache安装成功

安装PHP

#Centos 5.X:

rpm -Uvh http://mirror.webtatic.com/yum/el5/latest.rpm

#CentOs 6.x:

rpm -Uvh http://mirror.webtatic.com/yum/el6/latest.rpm

#CentOs 7.X:

rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm

rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

4.安装新的版本

yum install -y php71w php71w-cli php71w-common php71w-devel php71w-embedded php71w-fpm php71w-gd php71w-mbstring php71w-mysqlnd php71w-opcache php71w-pdo php71w-xml php71w-ldap php71w-mcrypt

根据提示输入Y直到安装完成。

apache默认的程序目录是/var/www/html

复制网站文件

环境搭建好了,就要拷贝文件了。这次要从原有网站把完整目录拷贝到云主机,不过我怎么拷贝呢。想到最简单的办法就是通过FTP上传文件了。于是百度如何开启FTP服务。

yum install -y vsftpd

vsftpd默认设置为禁止root账户登录,开启的方式如下:

1.编辑/etc/vsftpd/user_list和/etc/vsftpd/ftpusers两个设置文件脚本,将root账户前加上#号变为注释。(即让root账户从禁止登录的用户列表中排除)

2.重新开启vsftpd   service vsftpd reload

允许root账户访问ftp,可以远程访问centos系统中的任一文件,对于远程维护centos系统或下载文件十分方便。但从安全角度考虑,最好为临时性开启,平常还是把它关掉吧。

FTP配置文件地址:/etc/vsftpd/vsftpd.conf

Mac下之前我用的是ForkLift访问FTP,这次我用它访问原有和现在的主机,并开始拖动上传文件。一切正常,但是访问网站发现网页不显示图片,原来是图片是中文名,而ForkLift对中文名显示乱码。

于是开始找有没有其他FTP工具,找了一个Transmit,发现还是乱码,又搜索如何解决乱码问题,发现在Transmit中的View菜单选择文本编码为GB 2312,接着拷贝正常,网页显示正常。

  • 启动Vsftpd服务:service vsftpd start
  • 设置vsftpd开机启动, systemctl enable vsftpd
  • 重新启动Vsftpd服务的命令为:service vsftpd restart
  • 在开机时禁用服务: systemctl disable vsftpd

备份恢复数据库

文件拷贝完了,就这就是恢复数据库了。原本想着把备份好的SQL文件上传到服务器,然后再去执行。想着现在对安全性也要求不高,简单一些,使用Navicat远程访问服务器执行SQL文件进行数据库恢复。

这步一切正常。

授权远程访问:

登陆:
最近总当机,IT帮网站用了1天时间成功搬家
 
使用mysql数据库(真正的数据库,而非数据库软件),将所有数据库的所有表(*.*)的所有权限(all privileges),授予通过任何ip(%)访问的root用户,密码为123456,最后刷新(flush privileges)即可。
最近总当机,IT帮网站用了1天时间成功搬家
 

开放防火墙端口:

通过vim修改/etc/sysconfig/iptables,添加一行(这里是为了简单添加一行,更多防火墙知识请自行学习):
最近总当机,IT帮网站用了1天时间成功搬家
 
 

重启防火墙:

最近总当机,IT帮网站用了1天时间成功搬家

取消授权远程访问操作如下:

1.use mysql;

2.revoke all privileges on *.* from 'root'@'%';

3.flush privileges;

SSH登录

重装系统后,再次用SSH登录出错。

The fingerprint for the RSA key sent by the remote host is

SHA256:ATOehkETYPhbLwhr3cjPKKAOS2Gzjyjr0Tnj8bjRKVs.

Please contact your system administrator.

Add correct host key in /Users/zhoujingen/.ssh/known_hosts to get rid of this message.

Offending ECDSA key in /Users/zhoujingen/.ssh/known_hosts:1

RSA host key for 118.89.233.120 has changed and you have requested strict checking.

Host key verification failed.

解决办法:ssh-keygen -R "你的远程服务器ip地址"

让wordpress正常

文件和数据库好了并不就意味着结束了,后面还有很多问题需要解决。例如这个:

Warning: mysql_connect(): Headers and client library minor version mismatch. Headers:50550 Library:50635 in /var/www/html/blog/wp-includes/wp-db.php on line 1142

解决办法是:

  1. yum remove php-mysql
  2. yum install php-mysqlnd

Fatal error: Call to undefined function mb_convert_encoding() in /var/www/html/blog/wp-includes/class-wp.php on line 146

解决办法是:

  1. 首先安装 php-mbstring库文件:yum install php-mbstring
  2. 之后,修改/etc/php.ini文件,在里面加一句: extension=mbstring.so

因为这时候域名还没有重新解析,所以wordpress在切换域名时文章链接会链接到以前的域名,而不是现在的IP,所以又遇到如何更改网站域名的问题。后来找到了几个办法,采用了在wp_option表去更改网站地址。中间好像还遇到了一些问题,没有一一记录,现在也懒得去回忆了。

让codeigniter正常

敏捷个人APP是使用codeigniter框架开发的,本以为这个比较简单,拷贝文件即可。但是因为window和Linux操作系统的差别,以前的代码运行不了,而我又没安装调试环境,所以遇到问题也不知道什么原因。

于是用了各种办法,打开codeigniter的DB Debug模式,然后尝试简单更改源码再运行的方式去发现问题,终于最后都解决了。

其中有这么几个问题:

require_once找不到文件,这个主要是我在window下使用的是 require_once( ‘..\application\libraries\class-phpass.php’); 正常,但是Linux文件系统和window不一样,这样的代码在CentOS则是错误的,

解决办法是:

  • centos下需要 require_once(dirname(__FILE__).’/’.”../libraries/class-phpass.php”);

还有一个问题是 Unable to locate the model you have specified:*_model 的问题,这还是windows和linux对文件名的处理不一致导致,windows下文件名是不区分大小写的,但是Linux是严格区分大小写的。

解决办法是:

  1. 修改所有的model,文件名全部小写
  2. class model_name , model_name 只有第一个字母是大写,其余一律小写

域名重新绑定

搬家后自己再简单测试了一下,发现OK了,于是开始域名绑定。域名绑定网上找了找,相对简单,我到域名解析的管理页面,绑定了www.zhoujingen.cn和zhoujingen.cn到云主机的IP地址,等待一个小时左右就重新绑定成功了。

折腾1天终于搞定了新主机

虽然问题一个接一个,不过有网络,这些也不是什么大问题,终于在1天后主机搞定了。IT帮网站、敏捷个人网站、敏捷个人APP均已成功搬家,大家仍旧按以前方式访问,所有改变都只是在后台而已。

最近总当机,IT帮网站用了1天时间成功搬家

以此记录一下这个过程,以便后期再次搬家时参考,也对那些PHP环境从window搬迁到Linux的人有帮助。

最近总当机,IT帮网站用了1天时间成功搬家

上一篇:Android—自定义控件实现ListView下拉刷新


下一篇:python全栈开发day112-CBV、flask_session、WTForms