【血的教训】玩 Ubuntu 遇到的致命问题(进不了系统)及 解决方案

时间:2023-03-09 09:43:16
【血的教训】玩 Ubuntu 遇到的致命问题(进不了系统)及 解决方案

【问题1】

按照文章“U盘安装Windows 7 + Ubuntu 14 双系统笔记”在 Windows 7 基础上安装了 Ubuntu 14 系统,实现双系统切换,某一天,

通过如下命令行

sudo apt-get remove sogoupinyin

删除“搜狗输入法”,结果重启系统后,再也进不了桌面,最可恶的是,按快捷键“Ctrl + Alt + F1” 也进不了终端命令行。

系统崩溃了,顿时感觉 Ubuntu 系统的各种不靠谱。

后来,把 Ubuntu 系统删除了,决定到 VirtualBox 中去折腾 Ubuntu。

再后来,发现 删除“搜狗输入法”得这样删:

$sudo dpkg  -l  so* 				# 找到“搜狗输入法”得 安装名
$sudo apt-get purge sogoupinyin # 卸载搜狗拼音输入法
$sudo dpkg -r sogoupinyin # 防止登陆不了桌面

详细删除操作,请参考:[百度经验]Ubuntu彻底卸载搜狗拼音输入法

【问题2】

在 VirtualBox 中安装了 Ubuntu 14,发现 桌面窗口的 3D 效果特别不好,有一种 用 3D 的技术去跑出 2D 效果的感觉,结果还没有Ubuntu老版本的 2D 显示效果好,特别卡。貌似 Ubuntu 14 已经移除了 2D 桌面,所以只能勉为其难地使用上了 3D 桌面。

无奈,重新安装了低版本得 Ubuntu 12,它自带了 2D、3D 版本的桌面,在虚拟机中,自动使用上了 2D 桌面,一点也不卡的感觉。

【问题3】

在 VirtualBox 中安装了 Ubuntu 12,并且每成功安装好了一个软件,都会习惯性地备份下虚拟机,当误操作导致系统崩溃了,好还原系统。貌似系统崩溃这块找到了很好得解决方案,结果某一天:

我打算安装QQ,按照“Ubuntu12.04安装QQ2012教程”安装的 QQ 启动失败,到“Ubuntu 软件中心”的“已安装”列表中又没有找到 QQ 的安装记录。看到没有用的 QQ 想关文件,我又觉得烦,好吧,直接 rm 删除,结果历史悲剧重演,重启系统后,进不了Ubuntu系统,终端也打不开,最最大的问题是,我辛辛苦苦加班写得 代码 又因为未及时提交SVN,彻底丢失了!

后来,为了预防出现 系统崩溃问题造成“数据/代码”文件丢失得现象,决定把 重要得“数据/代码”文件放到 Windows 系统磁盘上,通过“共享文件夹”的形式共享给 VirtualBox 中的 Ubuntu。

如何设置“共享文件夹”,可参考这篇文章:

Windows 7 共享文件夹 给 VirtualBox 中的 Ubuntu 14

但是,文章提到的“自动挂载”有点不爽的是,挂载路径为 /media/sf_ubuntu/。我想 自定义“自动挂载”、“挂载目录” 及“挂载目录的用户”,如何实现?

操作方式如下:

1、去掉 勾选“自动挂载”,如下图所示

【血的教训】玩 Ubuntu 遇到的致命问题(进不了系统)及 解决方案

2、查看当前用户(jianbao)的 uid、gid

$ cat /etc/passwd
...
saned:x:114:123::/home/saned:/bin/false
jianbao:x:1000:1000:jianbao,,,:/home/jianbao:/bin/bash
vboxadd:x:999:1::/var/run/vboxadd:/bin/false
mysql:x:1002:1002::/home/mysql:/usr/sbin/nologin
...

3、设置开机“自动挂载”

$ sudo mkdir /www         # 新建挂载目录
$ sudo vim /etc/rc.local

在 exit 0 代码前添加如下代码:

mount -t vboxsf ubuntu /www -o uid="1000",gid="1000"

表示把“共享文件夹”ubuntu 挂载到 /www 目录,并且 /www 目录的用户名及用户组分别为 1000,1000,即 jianbao,jianbao。

注意:如果不指定挂载目录 /www 的用户名的话,默认为 root。

以后SVN项目的代码文件统一放到 /www 目录下,再也不用担心 代码文件 因 Ubuntu 系统崩溃而造成数据丢失的问题了。

[温馨提示]

后面我把 Virtual Box 换成了 VMware Workstation,VMware默认挂载路径为 /mnt/hgfs/ubuntu/。没有用自定义挂载,而是采用 软链接 的方式,自定义访问目录!参考命令如下:

sudo ln -s /mnt/hgfs/ubuntu  ~/www
sudo ln -s /mnt/hgfs/ubuntu  /www

【问题4】

[问题3] 解决了 预防“代码文件”丢失的问题,但是 还有个 MySQL 数据库,如何处理?

1、把 MySQL 的 data 目录移到 /www 目录下(注意:配置文件中得 data 目录也得调整);

2、把 MySQL 的 运行用户名 由 mysql 改为 当前用户(jianbao)

后来,我干脆把 MySQL 的安装位置给整体调整了,由先前的 /opt/software/mysql 拷贝 一份为 /www/mysql 。

注意:有些生成的静态库拷贝不过去,即使是 root 权限也不行。主要是在编译安装PHP时,用到了编译参数:

--mysql=/opt/software/mysql --with-pdo-mysql=/opt/software/mysql --with-mysqli=/opt/software/mysql/bin/mysql_config

编译PHP时,会在 /opt/software/mysql 目录生成一些不可移动的(只读的),PHP(php-fpm)自身又需要用到的 MySQL 相关类库。

所以,不要删除 /opt/software/mysql 目录,也不要删除 mysql 用户。

另外,/www/mysql 中的数据库也不要重新“初始化安装”,即不要执行 “/www/mysql/scripts/mysql_install_db”等命令,只需要把类似 basedir,datadir 配置改下即可!

安装 MySQL 可参考:Ubuntu 12 安装 MySQL 5.6.26 及 问题汇总

【问题5】

[问题4]解决了 MySQL 数据存储位置转移问题,但是当我重启系统后,发现设置得 MySQL“自启动”没有生效,即启动失败。

“自启动”是通过以下命令安装服务实现的:

sudo update-rc.d mysqld defaults

通过查看 MySQL 的错误日志,提示说 /www/mysql 目录不存在。很显然,在开机后内核执行“service mysqld start”时,Windows下的“共享文件夹”ubuntu 还未开始(或还未成功)挂载到 /www 目录,所以导致 MySQL "自启动"失败。

同理,Nginx 也“自启动”失败。最后的解决方案如下:

$ sudo vim /etc/rc.local 

在 exit 0 代码前添加如下代码:

service nginx start
service mysqld start

删除通过工具 update-rc.d 设置的 Nginx、MySQL 开机自启动服务:

sudo update-rc.d -f mysqld remove
sudo update-rc.d -f nginx remove

注意:系统服务 service nginx start|stop|restart 是不会受影响的,只是开机的时不会去调用 service nginx start 罢了。

【问题6】

宿主主机 Windows 7 系统中装了 TortoiseSVN,在虚拟机 Ubuntu 系统中也安装了 SVN,当通过 PhpStorm 的 SVN 插件检出 SVN 项目时,拉取了几个文件后,报如下错误:

【血的教训】玩 Ubuntu 遇到的致命问题(进不了系统)及 解决方案

再次拉取时,提示 SVN 被锁定。猜想,应该是和宿主主机中的 TortoiseSVN 发生冲突了。当 Ubuntu 在拉取文件时,SVN 会更新项目目录下的 “.svn/wc.db”文件,它是个 sqlite 数据库文件,而此时,宿主主机中的 TortoiseSVN 也检测到了 SVN 项目目录在更新,也会去更新这个“.svn/wc.db”文件,两边同时更新同一文件,肯定会出现“文件锁竞争”问题,所以会报错:

svn:E200030:Additional errors:
svn:E200030:sqlite[S10]:disk I/O error

最后的解决方案是:卸载 Windows 7 中的 TortoiseSVN,以后直接在 Ubuntu 中管理SVN。

延伸阅读:

Ubuntu 管理开机自启动工具 update-rd.d 使用详解