[Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html

正文:

在本人的项目中,运行在路由器上的服务器采用Nginx+MySQL+PHP 架构。通常较为常见的web框架为Lamp(Linux+Apache+Mysql+PHP),为何我们选择LNMP呢?我将在后续的几篇文章中给出答案。

首先我们来介绍如何在Openwrt上搭建MySQL数据库。

参考文章:(http://blog.csdn.net/yufei_email/article/details/21845935

一、安装MySQL数据库(在backfire10.3版本中,package已经包含mysql-server.ipk)因此可以直接通过opkg安装。

opkg update
opkg install mysql-server

二、设置mysql配置文件(/etc/my.cnf)

1. 修改数据库存放的位置(在/etc/my.cnf中找到如下配置)

datadir            =/mnt/data/mysql
tmpdir =/mnt/data/tmp

 更改为:

datadir             =/mnt/sda3/data/mysql     #将数据库放置到U盘对应分区上存储
tmpdir =/mnt/sda3/data/tmp #将数据库临时文件夹存放到U盘对应分区上 #本人的数据库存放在U盘第三个分区上,也就是/mnt/sda3,大家根据自己的需要修改

2. 修改数据库的绑定地址(找到bind-address属性)

bind-address        =127.0.0.1

  更改为:

bind-address        =0.0.0.0

  修改的目的:允许远程访问。

  保存修改,并退出编辑。

3. 创建数据库存放文件夹(若my.cnf中datadir以及tmpdir对应存储位置不存在的话,进行此操作,否则跳过此步骤)

mkdir /mnt/sda3/data
mkdir /mnt/sda3/data/mysql
mkdir /mnt/sda3/data/tmp #更为简单的命令
# mkdir -p /mnt/sda3/data /mnt/sda3/data/mysql /mnt/sda3/data/tmp

4. 创建database(执行如下操作)

/usr/bin/mysql_install_db --force

三、启动MySQL数据库

1. 启动mysql守护进程

/etc/init.d/mysqld enable
/etc/init.d/mysqld start

2. 启动mysql server交互进程:

 使用过mysql的亲们都清楚,mysql数据库的操作需要对应用户有权限才行的。在刚刚建成的数据库还没有对用户设置密码。那该如何设置呢?有如下两种方法:

 方法一:

 使用mysqladmin命令预先设置对应用户mysql使用密码,以root用户为例:

/usr/bin/mysqladmin -u root password XXXXXX
# XXXXXX 是为root用户设置的密码

方法二:

 以非授权方式进入mysql,进行权限设置:

#以非授权的方式启动mysqld。
mysqld --skip-grant& #root用户登录mysql
mysql -u root #查看是否存在mysql数据库
show databases;
use mysql;
update user set Password=password('XXXXXX') where User='root' and Host='localhost'; flush privileges;
exit

Tips: 在此次修改中,我们仅仅设置了localhost的用户名和密码,其他权限均没有设置。如果需要,要另行设置。

关闭mysqld服务

killall mysqld

重启mysqld服务

/etc/init.d/mysqld start

在设置完密码和权限之后,以root用户登录Mysql:

mysql -u root -p

ok 到此Mysql就能正常登录和使用了。

四、遇到问题以及解决方法

在本人安装启动Mysql的时候,系统报错:

can't open library 'libncurses.so.' ...

在网上查看了各种帖子,发现大家说的都好高大上,什么内核版本不对,什么文件链接出错。几经修改,还是没有解决问题,后来无意中到查找,居然发现了libncurses的安装包。。。

http://downloads.openwrt.org/backfire/10.03/ar71xx/packages/

原来缺少libncurses的库文件的解决方法是:

opkg install libncurses

安装完毕之后,重启mysql服务即可正常登陆了。

下一节,介绍在Openwrt上安装PHP+MySQL。

转载请注明出处:http://www.cnblogs.com/double-win/ 谢谢!

[Openwrt 项目开发笔记]:MySQL配置(六)的更多相关文章

  1. [openwrt 项目开发笔记]: 传送门

    “Openwrt 项目开发笔记”系列传送门: [Openwrt 项目开发笔记]:Openwrt平台搭建(一) (2014-07-11 00:11) [Openwrt 项目开发笔记]:Openwrt平台 ...

  2. [Openwrt 项目开发笔记]:PHP+Nginx安装(七)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 在上一节中,我们已经搭建了MySQL数据库了,因 ...

  3. [Openwrt 项目开发笔记]:Openwrt平台搭建(一)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 最近开始着手进行Openwrt平台的物联网网关设 ...

  4. [Openwrt 项目开发笔记]:DDNS设置(五)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 在上一节中,我主要讲述了如何在Openwrt上安 ...

  5. [Openwrt 项目开发笔记]:Samba服务&vsFTP服务(四)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 在上一节中,我们讲述了如何在路由器上挂载U盘,以 ...

  6. [Openwrt 项目开发笔记]:USB挂载& U盘启动(三)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 在上一篇中,我结合Netgear Wndr370 ...

  7. [Openwrt 项目开发笔记]:Openwrt必要设置(二)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 前面的两篇blog中,我将如何搭建Openwrt ...

  8. [Openwrt 项目开发笔记]:Openwrt平台搭建(一)补遗

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 昨晚上熬夜写了[Openwrt项目开发笔记]:O ...

  9. Java开发笔记(九十六)线程的基本用法

    每启动一个程序,操作系统的内存中通常会驻留该程序的一个进程,进程包含了程序的完整代码逻辑.一旦程序退出,进程也就随之结束:反之,一旦强行结束进程,程序也会跟着退出.普通的程序代码是从上往下执行的,遇到 ...

随机推荐

  1. eclipse zg项目学习

    一.基本知识 1.新增测试系统: xx/jsp:用于摆放jsp xx/src:放置java source 2.在项目上,右键,New-Folder,新建xx文件夹. 同样的方法,在xx文件夹上,右键N ...

  2. Maven命令行使用 mvn clean package

    先把命令行切换到Maven项目的根目录,比如:/d/xxxwork/java/maven-test,然后执行命令:  mvn clean package 执行结果如下: [INFO] Scanning ...

  3. Python+Webdriver,中文前加u是unicode格式编码的意思

    Python+Webdriver写脚本时,对一些输入框赋值会涉及到输入中文,这时需要在中文前加u 举个例子,在用百度搜索时,要在搜索输入框内输入值, 我用的编码格式是utf-8,向输入框内输入值是:d ...

  4. struts2标签类别

    要在jsp中使用Struts2的标志,先要指明标志的引入.通过jsp的代码的顶部加入以下的代码: <%@taglib prefix="s" uri="/struts ...

  5. Java按值传递、按引用传递

    一般我们会说Java基本类型采用值传递,对象以及数组采用引用传递.但事实上这只是表面上的现象.实质上,Java都是按值传递引用.(Java中“引用”的概念相当于C++中的指针,可以不断改变值) 一,对 ...

  6. 转)ubuntu安装clang

    主要参考:http://blog.csdn.net/firebird321/article/details/48528569 1.下载源码 去http://llvm.org/releases/down ...

  7. jQuery中animate()对Firefox无效的解决办法

    在使用 animate()做返回顶部的动画时,会出现对Firefox无效的情况,如: $('body').animate({scrollTop:'0'},500); 它对Chrome,IE,Opera ...

  8. LayDate 时间选择插件的使用介绍 (低版本1.0好像是)

    <span style="font-size:18px;"><!doctype html> <html> <head> <me ...

  9. Java8 改进的匿名内部类:

    1.匿名内部类适合创建那种只需要一次使用的类 2.匿名内部类定义格式: new 实现接口() | 父类构造器(实参列表){ //匿名内部类类体部分 } 3.从上面定义格式可以看出,匿名内部类必须实现一 ...

  10. BZOJ 2726 [SDOI2012] 任务安排 - 斜率优化dp

    题解 转移方程与我的上一篇题解一样 : $S\times sumC_j  + F_j = sumT_i \times sumC_j + F_i - S \times sumC_N$. 分离成:$S\t ...