小碗汤 · 2019年10月18日

LAMP环境部署物联网项目

今天来在LAMP环境下搭建一个PHP项目,开始之前,先来普及下物联网常识:

物联网,即Internet of Things,简写IOT。让所有能行使独立功能的普通物体实现互联互通的网络,通过物联网可以用中心计算机对机器、设备、人员进行集中管理、控制,实现物物相连。近几年物联网在运输、物流、健康医疗、智能环境(家庭、办公、工厂)等领域都在迅速发展,前景打好。

B哥最近研究一个物联网项目:基本功能就是要在web网站和手机app端实时监控硬件上发来的数据,用于分析、集中管理与控制,硬件是基于ARM的,web端是用php开发的,基本功能可以跑起来,现在主要在这基础上实现自己的功能。上一节B哥已经在云服务器上搭建好LAMP环境(linux上安装LAMP笔记),接下来就要把web项目部署好服务器上。遇到了很多问题,在此一一记录。

image

其中项目代码结构如下:

image

先把项目传到服务器上,然后解压:

cd /var/www/html
unzip AdminIOT
#先把目录下文件权限改为777
chmod -R 777 AdminIOT

用以下命令查看httpd、php、mariadb的版本:

rpm -qa|grep -P "httpd|php|maria"

分别为2.4.6、5.4.16、5.5.56

image

配置apache服务器的时候httpd-vhosts.conf文件在/usr/share/doc/httpd-2.4.6目录下

(windows上好像直接在conf/extra/下),

于是在/etc/httpd/conf/httpd.conf中加入:

include /usr/share/doc/httpd-2.4.6/httpd-vhosts.conf,

结果启动时报错了。于是就把

/usr/share/doc/httpd-2.4.6/httpd-vhosts.conf文件复制到/etc/httpd/conf/extra目录下:

#创建目录
mkdir -p /etc/httpd/conf/extra
#复制
cp /usr/share/doc/httpd-2.4.6/httpd-vhosts.conf /etc/httpd/conf/extra

然后在extra下的httpd-vhosts.conf中添加如下配置:

  • DocumentRoot 为项目代码路径;
  • ServerName 服务别名,这里设置为域名,但是得在host文件里配置对应的IP,IP即为当前节点IP;
<VirtualHost *:80>
   ServerName www.mysmallsoup.com
   DocumentRoot "/var/www/html/AdminIOT/public"
   DirectoryIndex index.php
   <Directory "/var/www/html/AdminIOT/public">
       AllowOverride All
       Require all granted
       Options all
   </Directory>
   ErrorLog "/var/log/httpd/dummy-host2.example.com-error_log"
   CustomLog "/var/log/httpd/dummy-host2.example.com-access_log" common
</VirtualHost>

image

然后在http.conf配置文件中包含httpd-vhosts.conf文件:

cd /etc/httpd/conf
vim httpd.conf
#打开文件后在文件末尾加入以下配置:
Include conf/extra/httpd-vhosts.conf

image

然后将域名绑定IP:

vim /etc/hosts

加入IP 域名,如下:

120.79.147.88 www.mysmallsoup.com

然后重新启动httpd服务器:

systemctl restart httpd

注:如果直接在windows上用域名访问,得在windows的host里加IP 域名对应关系,但是加了以后访问会报如下错,因为域名得先备案才能用。所以下面都用IP访问。

image

然后在本地windows浏览器里访问http://120.79.147.88:80地址,报错:

date(): It is not safe to rely on the system's timezone settings:

image

然后在查到:

实际上,从 PHP 5.1.0 ,当对使用date()等函数时,如果timezone设置不正确,在每一次调用时间函数时,都会产生E_NOTICE 或者 E_WARNING 信息。而又在php5.1.0中,date.timezone这个选项,默认情况下是关闭的,无论用什么php命令都是格林威治标准时间,但是PHP5.3中好像如果没有设置也会强行抛出了这个错误的,解决此问题,只要本地化一下,就行了。

而我们使用的是PHP5.4版本,然后在php.ini文件中加入时区的配置:

vim /etc/php.ini#加入如下配置:date.timezone = "Asia/Shanghai"

image

加入以后,保存退出,重新启动apache服务,刷新页面,错误就解决了。

image

到这一步,说明项目部署流程已经打通,但是现在需要登录,那么肯定要在数据库里面先存入用户名密码等一些数据。接下来,先给数据库里导入些初始化数据。

数据库导入数据:

先重新启动数据库:

systemctl restart mariadb

然后试着在本地windows上用Navicat数据库管理工具导入sql脚本,用于数据库的初始化(建库、数据插入等),我习惯性的把端口写为3306(数据库默认端口),然后去连接,发现报错了:

image

然后去查看3306端口是否监听:

netstat -anp | grep 3306

查不到东西,说明3306端口没有监听,这就奇怪了。然后登陆数据库:

mysql -uroot -p数据库密码

登陆进去查看数据库端口:

show variables like 'port';

image

发现查到的端口竟然是0,然后又查了资料,发现是启动数据库的时候加了skip-networking导致的,启动时用了如下命令:

mysqld_safe --user=mysql --skip-grant-tables --skip-networking &

--skip-networking=0表示监听配置端口,默认监听3306,等于1或者--skip-networking不赋值表示跳过端口监听,此时监听0,网络不可访问数据库,只能数据库节点访问。可以通过以下命令查看:

show variables like 'skip_networking';

image

发现是ON,说明开启了skip_networking,接下来我们要关掉它。

查看mysql进程:

ps -ef | grep mysql

[图片上传中...(image-3ac06c-1571321042895-17)]

然后杀掉进程,重新启动数据库:

kill 12080
mysqld_safe --user=mysql --skip-grant-tables --skip-networking=0 &

然后再来查看3306端口是否监听:

netstat -anp | grep 3306

image

发现端口正常监听,然后登陆数据库,查看:

image

发现port为3306,skip_networking为OFF,此时再在windows上连接数据库,就ok了。

连接上数据库后,就可以导入sql文件了:

image

导入以后,打开刚才的web登陆页面,输入用户名和密码,发现验证码图片看不见:

image

然后去看运行日志:

cd /var/www/html/AdminIOT/runtime/log/201806
tailf 10.log

然后刷新验证码,报错Call to undefined function Think\imagecreate()

image

然后查看如下的说法:

在php中imagecreate函数是一个图形处理函数,主要用于新建一个基于调色板的图像了,然后在这个基础上我们可以创建一些图形数字字符之类的,但这个函数需要GD库支持,如果没有开启GD库使用时会提示Call to undefined function imagecreate()错误。

那就试着安装一下GD库吧,执行yum安装gd命令,然后重新启动apachce服务以使安装后的GD库生效。

yum -y install php-gd
systemctl restart httpd

然后刷新页面,验证码就可以正常显示了。登陆进去以后,又报错了:Call to undefined function think\mb_strlen()。

image

网上有人说,遇到上述错误,是未开启php_mbstring拓展,即找到php.ini里的

;extension=php_mbstring.dll把前面的;去掉,但是找了发现没有这个扩展配置,可能是因为版本较高的原因。在/etc/php.d目录下也没找到此扩展,然后就用yum安装一个吧,然后重启apache服务:

yum install -y php-mbstring
systemctl restart httpd

重启以后登录页面后这个错误就没了,但是又报另一个错误:

could not find driver

image

然后安装php-mysql,安装好后,重启apache服务:

yum install php-mysql.x86_64
systemctl restart httpd

重新登录页面,这个错误也过去了。又报另一个错误:

SQLSTATE[28000] [1045] Access denied for user 'iotadmin'@'localhost' (using password: YES)。

image

然后登陆数据库,授权iotadmin用户访问权限:

grant all privileges on adminiot.* to 'iotadmin'@'localhost' identified by 'iotadmin';
flush privileges;

执行完以后,再次刷新页面,报错就过去了。接下来的又是另一个错,错误如下图:

image

进后台去看运行日志10.log,报错如下:

cd /var/www/html/AdminIOT/runtime/log/201806/
tailf 10.log

image

找到代码Base.php的198行,如下:

image

代码报错:Arbitrary expressions in empty are allowed in PHP 5.5 only less,

大概意思就是说“不同类型的表达式用empty判空只有PHP5.5才”,而服务器上安装的是PHP5.4版本,所以就报这个错。这里不妨换一种方式写,只要逻辑是一样的。那就改成了这样,原来的写法先注释掉。

image

然后把文件替换到服务器对应路径下,重启apache服务,刷新页面,一切OK。

image

到这里web项目就正常跑起来了。一路走下来,步步是坑啊,做一下笔记,记录一下坑,以后肯定会用到的。



本公众号免费提供csdn下载服务,海量IT学习资源,如果你准备入IT坑,励志成为优秀的程序猿,那么这些资源很适合你,包括但不限于java、go、python、springcloud、elk、嵌入式 、大数据、面试资料、前端 等资源。同时我们组建了一个技术交流群,里面有很多大佬,会不定时分享技术文章,如果你想来一起学习提高,可以公众号后台回复【2】,免费邀请加技术交流群互相学习提高,会不定期分享编程IT相关资源。


扫码关注,精彩内容第一时间推给你

image

推荐阅读
关注数
1
文章数
116
微信公众号【我的小碗汤】博主,分享技术文章和记录编程中遇到的问题及解决方案,工作中提高效率的工具,推送原创文章及优秀文章等
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息