ubuntu vps 安装 docker 失败 Cannot connect to the Docker daemon at unix:///var/run/docker.sock.

详情见兴致冲冲的安装:

wget -qO- https://get.docker.com/ | sh

然后

docker info

输出:

Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?

通过 service docker restart 尝试没有变化, 查看 docker 的日志 tail -5f /var/log/upstart/docker.log 发现

time="2017-04-23T01:13:59.857654612-04:00" level=fatal msg="Your Linux kernel version 2.6.32-042stab116.2 is not supported for running docker. Please upgrade your kernel to 3.10.0 or newer."

所以问题是, 当前 linux 的 kernel 2.6 版本太低, 需要升级到 3.10 以上. 坑爹的 vps 自带模板[捂脸] 然后基于 OpenZV 6 的 vps 默认内核是 2.6, docker 需要基于 3.x 的内核, 只有 OpenZV 7 的 vps 才支持 (基于 3.x 内核).

qmlscene WARNING **: Unable to register app: Invalid application ID

编写 QML 的时候运行出现的警告:

$ /usr/bin/qmlscene hello.qml

unity::action::ActionManager::ActionManager(QObject*):
	Could not determine application identifier. HUD will not work properly.
	Provide your application identifier in $APP_ID environment variable.

** (qmlscene:12464): WARNING **: Unable to register app: GDBus.Error:org.freedesktop.DBus.Error.InvalidArgs: Invalid application ID

这个警告是因为没有指定应用 id(application ID),在命令的前面指明 APP_ID 这个环境变量即可:

$ APP_ID=hello /usr/bin/qmlscene hello.qml

如果是使用 ubuntu sdk 这个 IDE 编写的时候 Ctrl + R 运行报错。
请找到 Ubuntu SDK (其实就是定制版的 Qt Creator) 左侧的 【Projects】接着请找到Desktop下,Build旁边的 【Run】,然后在出来的界面中找到下方的 Rune Environment 下点击【Details】点添加,跟加 windows 的环境变量一样,加上一个 APP_ID 然后 value 比如项目名 hello 。
然后再来 Ctrl+R 就不会出现这个错误了。

另外 .desktop 文件中的 Exec 参数修改是不影响 Ubuntu sdk 运行的,那个文件中指明的是打包之后告诉你的 ubuntu 桌面如何运行的一个配置。

ubuntu sdk 安装 (ubuntu touch 开发环境)

按照官方的说法,最好使用 ubuntu 14.04 来进行开发。安装的过程很简单:

sudo add-apt-repository ppa:ubuntu-sdk-team/ppa
sudo apt-get update
sudo apt-get install ubuntu-sdk

其过程就是添加一个 SDK Release PPA 的地址,然后更新 apt-get,接着使用 apt-get 来直接安装 ubuntu sdk。
不过博主直接安装有报错:

W: Failed to fetch http://us.archive.ubuntu.com/ubuntu/dists/trusty-updates/universe/binary-amd64/Packages  Hash Sum mismatch
W: Failed to fetch http://us.archive.ubuntu.com/ubuntu/dists/trusty-updates/main/binary-i386/Packages  Hash Sum mismatch
W: Failed to fetch http://us.archive.ubuntu.com/ubuntu/dists/trusty-updates/universe/binary-i386/Packages  Hash Sum mismatch
E: Some index files failed to download. They have been ignored, or old ones used instead.

原因就如英文原文所说的 old ones used,有些库太老了,需要更新。这个时候你需要

sudo apt-get dist-upgrade

之后再 sudo apt-get install ubuntu-sdk 就可以了。等安装好了之后就可以在菜单里面搜索 ubuntu sdk 找到,或者直接在 terminal 上运行:

ubuntu-sdk

命令也可以运行该 IDE。

小Tip:Ctrl + N 新建项目,Ctrl + R 查看运行效果

源引官方文档:Installing the ubuntu sdk

ubuntu 12 升级到 14 错误记录 no suitable download server was found

博主是按官方文档走出的错,这里是官方文档出处:http://www.ubuntu.com/download/desktop/upgrade
所以最开始附上一种跟官方文档流程不一样的,各位也可以尝试一下:http://ubuntuserverguide.com/2014/06/how-to-upgrade-ubuntu-server-12-04-to-ubuntu-server-14-04-lts.html

按照官方文档,最初说是按下菜单键(win图标),然后输入 updater 选第一个就是了。会自动更新。
如果你找不到也可以用 terminal 运行 sudo update-manager -d。

不过等了一会之后报了很多错,错误内容是:no suitable download server was found 很多地址 404 之类的。要我检查网络。
后来研究了好一阵子,找到一个解决方案。ubuntu software center 上面选 Edit -> software source, 更改了更新的地址。
结果还是不行。然后通过自动【select best server】也弹出来说没有合适的,要我检查网络。

最后只能求助谷歌。找到如下方法:

sudo sed -i -e 's/archive.ubuntu.com|security.ubuntu.com/old-releases.ubuntu.com/g' /etc/apt/sources.list
sudo apt-get update && sudo apt-get dist-upgrade
sudo update-manager -d。

这个方法貌似人气很高,但是我试过了没用。log 上一堆 404 提示跟开始差别不大。

后来继续看,老外说是版本太久了所以默认设置的更新地址都没法起作用。
我了个去,Ubuntu 12.04 不是说维护 5 年吗,我才用了 2 年啊喂!
所以,附上最后找到的办法:
1.打开更新配置文件

gksudo gedit /etc/apt/sources.list

2.在出来的文件里面从上往下找到一个不是以 # 开头的那行. 假设你的编辑器是 Karmic Koala (Ubuntu 9.10) 看起来像是这样的:

deb <网站url> karmic main restricted

这里, 就是你的默认更新请求的地址,例如:http://gb.archive.ubuntu.com/ubuntu
或者向博主这样:

deb http://mirrors.163.com/ubuntu/ quantal main restricted

这是博主刚刚用 software center 改了以后的更新地址。这其中的 http://mirrors.163.com/ubuntu/ 就是我们要修改的部分。

3.按下 Ctrl + H 使用 http://old-releases.ubuntu.com/ubuntu 来替换你当前的 ,

如果你的ubuntu也是英文,看起来就像这样:
Search for: 例如 http://mirrors.163.com/ubuntu/;
Replace with: http://old-releases.ubuntu.com/ubuntu
然后按下 Replace All (替换全部)

4.再来一遍 (博主没有做直接跳过也成功了)

Search for: http://security.ubuntu.com/ubuntu (该 url 用于所有版本的 Ubuntu)
Replace with: http://old-releases.ubuntu.com/ubuntu
然后按下 Replace All

5.保存文件,然后打开 terminal 运行:

sudo apt-get update
sudo update-manager -d。

等了一会,好的,software updater 终于正常了!点击 install now,慢慢开始更新了!

更新完之后重启,我从 12.04 升级到了 12.10。并没有直接从 12 升级到 14。好吧,不过 updater 也终于正常了。于是再重复最开始的操作。

按照官方文档,最初说是按下菜单键(win图标),然后输入 updater 选第一个就是了。会自动更新。
如果你找不到也可以用 terminal 运行 sudo update-manager -d。

然后提示我已经没有 12 版本的更新了,提示升级到 13.10。自然点升级。接下来一路这个流程就升级上去了。

援引问答地址:how to install software or upgrade from old unsupported release

局域网想要DNS指向自己服务器的解决方案(主机名称的作用)

原本想使用路由添加 DNS 记录,来指向局域网测试的服务器。结果意外的发现了一种非常简单的办法。那就是通过修改当前主机的名称来实现局域网内的一个“模拟域名”。

博主这里用的是 win7 的操作系统,刷系统的时候用户名写的是 Lellansin,于是我的电脑主机名也就默认的变成了: Lellansin-PC

于是情况就来了,我们打开 cmd,输入:

ping Lellansin-PC

你会发现,这其实是 ping 的通的。这也意味着,在局域网测试的时候,原本通过 192.168.1.XX/test.php (当前计算机在局域网中的ip + 网站路径) 的访问方式可以通过使用 lellansin-pc/test.php 来代替。如果你把当前计算机的名称改为 pms 的话也可以通过 pms/test.php 来访问。

不过貌似 windows 上改名字的时候不能加点(有知道的望留言提醒),不然改成 http://www.test.com 也是极好的。

在 linux 上的话就会自由一些,通过:

sudo vim /etc/hostname

我就直接把局域网里测试用的服务器的主机名改成了 http://www.testgame.com ,尝试确实是可以用的。

MySql ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2)

最开始的时候,技术反应 mysql 连接成功,但是调用超时。然后老板知道了这事选择直接重启(这真是一个错误的决定)。重启之后 mysql 就起不来了。接着我便被老板叫来解决问题。首先是运行看了看:

service mysql start
# 启动 mysql,报错 启动失败

mysql
# ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

网上说这个错误的文章有很多,但是最最重要的一点都是要求查看 mysql 的错误日志(错误日志目录由 mysql 配置文件指定)。有的人在日志里面发现时启动的时候某个文件打不开,去查看发现没有打开权限,修改权限之后就顺利启动了。不过博主碰到有点不同,他的错误日志是这样的:

... 
140422  7:00:17 [Warning] Disk is full writing './cobub/razor_login_log.MYD' (Errcode: 28). Waiting for someone to free space... (Expect up to 60 secs delay for server to continue after freeing disk space) 
140422  7:00:17 [Warning] Retry in 60 secs. Message reprinted in 600 secs
...

原来是服务器磁盘满了。。坑爹么这!!

df -ah     # 查看了一下发现硬盘已经 100% 了
cd /
du -sh *   # 从跟目录开始查看大小情况

# 反复根据上述命令来寻找异常大小的文件夹

最后发现居然是 nginx 的日志文件过大,访问+错误日志加起来约 14G。

但是删掉之后空间还是没有释放出来,当时不清楚是什么原因 reboot 重启服务器之后,空间就腾了出来 mysql 启动的问题就解决。

事后发现应该是被删除的文件还在被进程(nginx)访问,所以删除后并不会立即腾出空间。在碰到这个问题可以通过 lsof 命令来查看文件的占用,对应上述的情况为重启 nginx 来解决。

总结:

  • 出现异常第一时间要去看错误日志 啊,混蛋!!
  • 访问日志要定时清理 !!
  • 要注意监视服务器状态(内存、硬盘、CPU…)

linux tar not in gzip format

解压文件时出现如下问题:

$ tar -zxvf ./lellansin.tar.gz
gzip: stdin: not in gzip format
tar: Child returned status 1
tar: Error is not recoverable: exiting now

可以考虑将 z 参数换成 j参数问题解决, ( bz2格式用j, gz格式用z ) 如果都不行的话就直接

tar -xvf ./lellansin.tar.gz

不过这样解压的速度有点慢,可以考虑使用 nohup 将命令转到后台, 避免终端超时

nohup tar -xvf ./lellansin.tar.gz &