linux系统对权限的控制很好,但也成为各种问题的多发地,毕竟大家pc用习惯了,诸如访问权限等的很多安全问题根本不在考虑范围。
目的:把我的ubuntu中存放mysql数据的地方换个磁盘,因为满了,或者担心现在测试数据太多
方法1:把整个/var目录切换如新的磁盘
失败。见这里的分析:Ubuntu下移动/var目录到单独分区后出现的一些问题
方法2:把/var/lib/mysql用软连接目录切换到/home/fantaxy下
失败。原因应该是权限问题。
mysql对权限做了限制,必须是mysql:mysql。如果移动到这个目录下,因为上层的目录权限是fantaxy:fantaxy,这会造成mysql用户首先不能通过这个目录。
方法3:直接把/var/lib/mysql目录copy到了另一个磁盘的根目录下
成功。原因:屏蔽了上面说的linux自己的问题,和用户权限的问题。
----------------------/var/lib/mysql这个mysql默认的数据存放位置下的文件---------------------
如果没有修改权限,这个目录可能看不见,或者cd命令进不去
drwx------ 2 mysql mysql 4096 Aug 4 2012 blog/
drwx------ 2 mysql mysql 4096 Aug 6 2012 blog_test/
drwx------ 2 mysql mysql 36864 May 6 16:05 db_book_author/
-rw-r--r-- 1 root root 0 Jul 24 2012 debian-5.5.flag
drwx------ 2 mysql mysql 4096 Jan 5 14:20 hello_rails_development/
drwx------ 2 mysql mysql 4096 Jul 31 2012 hello_rails_test/
-rw-rw---- 1 mysql mysql 136314880 Jun 10 17:58 ibdata1
-rw-rw---- 1 mysql mysql 5242880 Jun 10 17:58 ib_logfile0
-rw-rw---- 1 mysql mysql 5242880 Jun 9 23:27 ib_logfile1
drwx------ 2 mysql mysql 4096 Dec 5 2012 jpetstore/
drwx------ 2 lijg root 4096 Jul 24 2012 mysql/
-rw-rw---- 1 root root 6 Jul 24 2012 mysql_upgrade_info
drwx------ 2 mysql mysql 4096 Jul 24 2012 performance_schema/
drwx------ 2 mysql root 4096 Oct 19 2012 test/
drwx------ 2 mysql mysql 4096 Oct 15 2012 wordpress/
自己的每个数据库都有对应目录,之下是存放数据的文件等。
---------------------------------下文的操作步骤,在ubuntu12上也测试通过了-----------------------------
在Ubuntu下安装的MySQL默认配置下的数据库文件存储位置是在/var/lib/mysql,如果你没有为/var挂载在一个足够大的分区 中,那么/var将和根目录/同在一个分区共享使用可用空间。大多数用户通常会为/home挂载一个独立的分区,所以这篇文章就是准备讲如何更改 MySQL数据库存储位置到其它挂载位置的。
MySQL数据库的文件结构是怎么样的呢,对于这样子创建的数据库命令:
CREATE DATABASE mysqldb |
在默认的数据库存储位置下就会有个文件夹mysqldb。要操作数据库首先得停止数据库进程:
$sudo /etc/init.d/mysql stop |
本文以转移到/home/mysql这个位置为例,下面命令将原有数据库转移到新位置:
$sudo cp –R –p /var/lib/mysql /home/mysql |
编辑MySQL配置文件:
$gksu gedit /etc/mysql/my.cnf |
在 gedit中找到datadir这一行,将后面等于号之后的内容更改为/home/mysql然后保存退出。自Ubuntu 7.10开始,
Ubuntu就开始使用一种安全软件叫做AppArmor,这个安全软件会在你的文件系统中创建一个允许应用程序访问的区域(专业术语:应 用程序访问控制)。如果不为MySQL修改AppArmor配置文件,永远也无法为新设置的数据库存储位置启动
数据库服务。配置AppArmor:
$sudo nano /etc/apparmor.d/usr.sbin.mysqld |
在gedit中找到/var/lib/mysql/这两行,注释掉这两行,在这两行前分别添加一个符号“#”即可注释,在这两行之前或
之后加上下面内容:
/home/mysql/ r, |
保存后退出,执行命令:
$sudo /etc/init.d/apparmor reload |
返回Reloading AppArmor profiles : done.即可以重启MySQL服务:
$sudo /etc/init.d/mysql start |
至此MySQL数据库存储位置就更改完毕了。
FAQ:
Q:当我运行$sudo /etc/init.d/apparmor reload却返回信息
Skipping profile /etc/apparmor.d/usr.sbin.mysqld~ |
并且也无法启动MySQL服务,怎么办呢?
A:出 现这个问题可能是因为你使用了$sudo gedit或$gksu gedit这样子的命令来编辑usr.sbin.mysqld这个配置文件的,这两个图形界面文本编辑器会在相同位置生成一个 usr.sbin.mysqld~的文件,从而影响了AppArmor读取配置文件,出现这个问题先删除这个usr.sbin.mysqld~文件:
$sudo rm /etc/apparmor.d/usr.sbin.mysqld~
然后使用$sudo nano这个终端文本编辑器来编辑配置文件即可。
相关推荐
- 链接与文件管理:软链接、硬链接的概念,以及如何有效管理文件和目录。 7. **系统服务与网络配置** - 网络服务:讲解网络配置,包括无线网络、有线网络、虚拟网络接口等。 - SSH远程访问:如何配置和使用SSH...
通过软链接将phpMyAdmin与Apache的`/var/www/`目录关联起来,如`sudo ln -s /usr/share/phpmyadmin /var/www/`。 7. **权限设置**: 由于安全考虑,`/var/www/`目录默认权限限制了普通用户的读写操作。你可以使用`...
使用软链接将phpMyAdmin目录添加到Apache的网站根目录,运行`sudo ln -s /usr/share/phpmyadmin /var/www/html`。然后,通过`http://localhost/phpmyadmin`访问phpMyAdmin。 在完成这些步骤后,你应该有一个功能...
MySQL 是一种广泛使用的开源关系型数据库管理系统,是 LAMP 环境中的数据存储部分。可以通过以下命令进行安装: ```bash sudo apt-get install mysql-server ``` 安装过程中会提示设置 root 用户的密码,请按照...
分享者:讲究不将就,来自原文地址 一:ubuntu开发环境PHP+MYSQL+APACHE2 1.sudo apt-get install apache2 2.安全组添加80端口 ...6.建立软连接 sudo ln -s /usr/share/phpmyadmin phpmyadmin 二:ubu
由于默认不在`/var/www`下,你可以创建软链接或将其移动至此目录。 三、启动和测试服务 1. 重启Apache以应用配置更改: ``` sudo /etc/init.d/apache2 restart ``` 2. 测试Apache:访问`http://localhost`,应显示...
通常情况下,这些文件会存储在`/var/cache/apt/archives`目录下。 **15. 备份当前系统安装的所有包的列表** `dpkg --get-selections > packages.list`可以保存已安装包的列表。 **16. 从上面备份的安装包的列表...
- **查看安装软件时下载包的临时存放目录**:APT 下载的包默认保存在 `/var/cache/apt/archives/` 目录。 - **备份当前系统安装的所有包的列表**:使用 `dpkg --get-selections > installed-packages.txt` 将已安装...
你需要一个运行良好的数据库系统(如MySQL、PostgreSQL或Oracle)来存储监控数据,以及PHP和Apache或Nginx这样的Web服务器来运行Zabbix前端。 2. **安装数据库** 根据你的选择,安装相应的数据库系统。例如,对于...
根目录`/`下包含系统主要目录,如`bin`存放基本命令,`etc`存储配置文件,`home`为用户主目录,`var`保存运行时可变数据,`boot`包含启动所需文件。文件权限由读(r)、写(w)和执行(x)三个标志组成,通过`ls -l`...
硬链接是指向文件实际数据块的另一条路径,与软链接不同的是,硬链接指向文件本身而不是文件名。 **创建硬链接:** - `ln /path/to/original /path/to/hardlink`:创建硬链接。 #### 19. 查看网络配置信息 **命令...
2. **安装MySQL**:MySQL是常见的关系型数据库管理系统,用于存储Laravel应用的数据。安装命令如下: ``` sudo apt-get install mysql-server mysql-client ``` 在安装过程中,系统会提示设置MySQL的管理员密码...
10. **系统日志与监控**:理解`dmesg`、`syslog`和`/var/log`目录下的日志文件,以及使用`top`、`htop`、`vmstat`、`iostat`等工具监控系统性能。 11. **防火墙与安全**:介绍iptables防火墙规则设置,以及使用`ssh...