0%

在之前做了Jenkins + Git + Maven的持续集成解决方案,今天访问Jenkins,异常缓慢,进控制台监控,发现磁盘不知道由于什么原因,竟然被塞满了.连基本的Tab键都不起作用了…这叫一个莫名其妙.于是赶紧找占满磁盘的文件到底是何方神圣.

1
du -ah --max-depth=1

通过一层一层查找,最终定位到Tomcat的日志文件,足足有8个G(我服务器也就20G,还包含系统).打开一看,都是这种

1
2
3
4
5
6
question: [DNSQuestion@1446063419 type: TYPE_IGNORE index 0, class: CLASS_UNKNOWN index 0, name: ]
question: [DNSQuestion@1395874330 type: TYPE_IGNORE index 0, class: CLASS_UNKNOWN index 0, name: ]
question: [DNSQuestion@1348504482 type: TYPE_IGNORE index 0, class: CLASS_UNKNOWN index 0, name: ]
question: [DNSQuestion@1919902183 type: TYPE_IGNORE index 0, class: CLASS_UNKNOWN index 0, name: ]
question: [DNSQuestion@1295053725 type: TYPE_IGNORE index 0, class: CLASS_UNKNOWN index 0, name: ]
question: [DNSQuestion@1221193730 type: TYPE_IGNORE index 0, class: CLASS_UNKNOWN index 0, name: ]

那么首先先恢复服务器吧,清空日志文件.这里要注意一点,

1
/usr/local/apache-tomcat-8.5.11/logs/catalina.out

这个文件是Tomcat的日志文件,被Tomcat占用,当Tomcat运行中虽然我们可以调用

1
rm -rf /usr/local/apache-tomcat-8.5.11/logs/catalina.out

删掉他,但实际上还是被进程锁定的,不会释放空间.那么只能先停止锁定它的进程Tomcat,再删除它.

不过,我们还有另一种办法,

1
echo > /usr/local/apache-tomcat-8.5.11/logs/catalina.out

我们不删除它,而是重写它,这样就可以在Tomcat不重启的情况下清空日志了.

OK,服务恢复了,但是这只解决了问题,没有找到原因,经过一番摸索找到了下面一片文章 http://stackoverflow.com/questions/31719756/how-to-stop-jenkins-log-from-becoming-huge

解决方法:在 Jenkins => 系统管理 => System Log => 日志级别 中添加

1
2
名称:javax.jmdns
级别:off

经过测试,通过以上方法确实解决了问题.感谢!

上篇文章描述了搭建Tomcat的过程,这次研究一下Jenkins的搭建. 首先下载主角Jenkins的war包跑起来,我是直接扔到Tomcat的Webapps… https://jenkins.io/index.html http://mirrors.jenkins.io/war-stable/latest/jenkins.war 版本2.32.1

跑的过程中会生成一个随机密码,防止有人恶意激活Jenkins…

然后是安装插件,这个比较坑,网络差的时候老是失败!

这次我们是要搭建Jenkins + Git + Maven,那么Git和Maven是少不了的. 正常情况下Git的插件是自动安装的,我们要手动安装Maven插件.名字是这个 Git plugin Git client plugin Maven Integration plugin 登录Jenkins之后依次点击系统管理,管理插件,可选插件,然后右上角有个搜索框,输入上面的插件名字就可以了,搜索出来之后点击安装即可.

安装完了之后回到Jenkins首页,就可以开始创建Maven项目啦!但是,在这之前还需要安装Git和Maven,Git我用yum安装的.版本是1.8.3.1

1
yum install git

至于Maven嘛,首先当然是去下载啦~ http://maven.apache.org/download.cgi 我这里使用的目前最新的3.3.9版本

1
wget http://apache.fayea.com/maven/maven-3/3.3.9/binaries/apache-maven-3.3.9-bin.tar.gz

速度还是挺快的~然后就把它解压出来就可以了

1
2
tar -zxvf apache-maven-3.3.9-bin.tar.gz
mv apache-maven-3.3.9 /usr/local/

OK,完成上面的操作之后再回到Jenkins,开始配置 依次点击Jenkins的系统管理,Global Tool Configuration. 开始配置JDK,Git,Maven JDK名字随意,去掉自动安装的勾 JAVA_HOME填写JDK的路径 Git,Maven同样…就一笔带过

这里要插一下,Git版本库密钥什么的就不在这里写了~又不懂得百度问我都行~ 另外,在我大中华区建议给Maven配置一下中央仓库镜像,快到飞起~可参见我前面的文章记录~

OK,上面配置不报红色错误就可以去新建项目啦~ 回到首页,新建项目,选择Maven项目,填写Git仓库地址,构建前参数,构建参数,构建完成参数~

OK,跑起~

Tomcat 8启动很慢,且日志上无任何错误,在日志中查看到如下信息:

1
2
3
Log4j:[2015-10-29 15:47:11]  INFO ReadProperty:172 - Loading properties file from class path resource [resources/jdbc.properties]
Log4j:[2015-10-29 15:47:11] INFO ReadProperty:172 - Loading properties file from class path resource [resources/common.properties]
29-Oct-2015 15:52:53.587 INFO [localhost-startStop-1] org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [342,445] milliseconds.

分析

Tomcat 7/8都使用org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom类产生安全随机类SecureRandom的实例作为会话ID,这里花去了342秒,也即接近6分钟。

SHA1PRNG算法是基于SHA-1算法实现且保密性较强的伪随机数生成器。

在SHA1PRNG中,有一个种子产生器,它根据配置执行各种操作。

1)如果Java.security.egd属性或securerandom.source属性指定的是 file:/dev/random 或 file:/dev/urandom ,那么JVM会使用本地种子产生器NativeSeedGenerator,它会调用super()方法,即调用SeedGenerator.URLSeedGenerator(/dev/random)方法进行初始化。

2)如果java.security.egd属性或securerandom.source属性指定的是其它已存在的URL,那么会调用SeedGenerator.URLSeedGenerator(url)方法进行初始化。

这就是为什么我们设置值为 file:///dev/urandom 或者值为 file:/./dev/random 都会起作用的原因。

原因

在这个实现中,产生器会评估熵池(entropy pool)中的噪声数量。随机数是从熵池中进行创建的。当读操作时,/dev/random设备会只返回熵池中噪声的随机字节。/dev/random非常适合那些需要非常高质量随机性的场景,比如一次性的支付或生成密钥的场景。

当熵池为空时,来自/dev/random的读操作将被阻塞,直到熵池收集到足够的环境噪声数据。这么做的目的是成为一个密码安全的伪随机数发生器,熵池要有尽可能大的输出。对于生成高质量的加密密钥或者是需要长期保护的场景,一定要这么做。

什么是环境噪声:
随机数产生器会收集来自设备驱动器和其它源的环境噪声数据,并放入熵池中。
产生器会评估熵池中的噪声数据的数量。
当熵池为空时,这个噪声数据的收集是比较花时间的。
这就意味着,Tomcat在生产环境中使用熵池时,会被阻塞较长的时间。

解决办法

1)在Tomcat环境中解决

可以通过配置JRE使用非阻塞的Entropy Source。

在catalina.sh中加入这么一行:

1
-Djava.security.egd=file:/dev/urandom

即可。

加入后再启动Tomcat,整个启动耗时下降到Server startup in 2912 ms。

2)在JVM环境中解决

打开$JAVA_PATH/jre/lib/security/java.security这个文件,找到下面的内容:

1
securerandom.source=file:/dev/random

替换成

1
securerandom.source=file:/dev/urandom

##一.安装JDK

因为Java JDK区分32位和64位系统,所以在安装之前必须先要判断以下我们的Centos系统为多少位系统,命令如下:

1
uname -a

解释:如果有x86_64就是64位的,没有就是32位的。后面是X686或X86_64则内核是64位的,i686或i386则内核是32位的.由此可以判断我的CentOS为64位系统,故而我需要下载64位系统的JDK。

下载传送门: http://www.oracle.com/technetwork/java/javase/downloads/index.html 注意要先点击Accept License Agreement,才能点击下载链接.

例如: http://download.oracle.com/otn-pub/java/jdk/8u121-b13/e9e7ea248e2c4826b92b3f075a80e441/jdk-8u121-linux-x64.tar.gz

这个地址直接用wget是下载不下来的.要禁用cookie.这样:

1
wget --no-check-certificate --no-cookies --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u121-b13/e9e7ea248e2c4826b92b3f075a80e441/jdk-8u121-linux-x64.tar.gz

下载好之后,解压到想要安装的目录.

1
2
tar -zxvf jdk-8u121-linux-x64.tar.gz
mv jdk1.8.0_121 /usr/local/

接下来,就是配置环境变量了:

1
vim /etc/profile

打开之后按键盘(i)进入编辑模式,将下面的内容复制到底部

1
2
3
4
JAVA_HOME=/usr/local/jdk1.8.0_121
PATH=$JAVA_HOME/bin:$PATH
CLASSPATH=$JAVA_HOME/jre/lib/ext:$JAVA_HOME/lib/tools.jar
export PATH JAVA_HOME CLASSPATH

备注:根据上面的配置信息,我们既可以将环境变量的配置完成,需要注意的是,PATH在配置的哦时候,一定要把AVA_HOME/bin放在最前面,不然使用java命令式,系统会找到以前的JAVA,在不往下找了,这样java这个可执行文件运行的目录其实不在$JAVA_HOME/bin下,而在其它目录下,会造成很大的问题。

写完之后我们按键盘(ESC)按钮退出,然后按(:wq)保存并且关闭Vim。 配置完成之后,最重要的一步就是使文件立即生效:命令如下:

1
source /etc/profile

上面所有的步骤完成之后,这时候我们需要检查是否安装成功:

1
2
java -version
echo $JAVA_HOME

出来的配置和我们的版本和路径一致即表示成功.

##二.安装Tomcat

首先我们下载Tomcat,我这里使用的版本是8.5.11.传送门: http://tomcat.apache.org/download-80.cgi

拿到下载地址后使用wget下载下来.

1
wget http://mirrors.cnnic.cn/apache/tomcat/tomcat-8/v8.5.13/bin/apache-tomcat-8.5.13.tar.gz

然后解压:

1
2
tar -zxvf apache-tomcat-8.5.13.tar.gz
mv apache-tomcat-8.5.13 /usr/local/

这时候,Tomcat已经可以正常启动了,进入tomcat目录执行

1
./bin/startup.sh

出现Tomcat Started.则表示成功开始启动.

我们也可以跟踪日志:

1
tail -f ./logs/catalina.out

当然,这之后要检查一下防火墙.避免被防火墙拦截.

到这里,我们已经完成了对tomcat的安装,接下来就可以部署项目,但是这里存在一个问题,那就是Linux的系统和重启我们每次都需要接路径并且执行命令,那么我们可以设置成service的形式来实现这个功能。

执行命令:

1
vim /etc/rc.d/init.d/tomcat

创建脚本文件,在文件中写入如下代码,保存并且退出

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/bin/bash
# /etc/rc.d/init.d/tomcat
# init script for tomcat precesses
# processname: tomcat
# description: tomcat is a j2se server
# chkconfig: 2345 86 16
# description: Start up the Tomcat servlet engine.
if [ -f /etc/init.d/functions ]; then
. /etc/init.d/functions
elif [ -f /etc/rc.d/init.d/functions ]; then
. /etc/rc.d/init.d/functions
else
echo -e "\atomcat: unable to locate functions lib. Cannot continue."
exit -1
fi
RETVAL=$?
CATALINA_HOME="/usr/local/apache-tomcat-8.5.11" #tomcat安装目录,你安装在什么目录下就复制什么目录
case "$1" in
start)
if [ -f $CATALINA_HOME/bin/startup.sh ];
then
echo $"Starting Tomcat"
$CATALINA_HOME/bin/startup.sh
fi
;;
stop)
if [ -f $CATALINA_HOME/bin/shutdown.sh ];
then
echo $"Stopping Tomcat"
$CATALINA_HOME/bin/shutdown.sh
fi
;;
*)
echo $"Usage: $0 {start|stop}"
exit 1
;;
esac
exit $RETVAL

给文件添加权限,使得脚本文件可以执行,命令为

1
chmod 755 /etc/rc.d/init.d/tomcat

将其添加到服务中,命令为

1
chkconfig --add /etc/rc.d/init.d/tomcat

然后将下面的配置文件加到tomcat中的catalina.sh文件中的最后面,命令为:

1
vim /usr/local/apache-tomcat-8.5.13/bin/catalina.sh
1
2
3
4
export JAVA_HOME=/usr/local/jdk1.8.0_121   #javajdk的安装路径,使用echo $JAVA_HOME命令可以读取
export CATALINA_HOME=/usr/local/apache-tomcat-8.5.11
export CATALINA_BASE=/usr/local/apache-tomcat-8.5.11
export CATALINA_TMPDIR=/usr/local/apache-tomcat-8.5.11/temp

以上所有工作顺利进行并且没有报错,则配置完成,你可以输入命令service tomcat start和service tomcat stop进行验证(请自行实验)。

通过上面的设置我们可以很方便的设置tomcat的启动和关闭,但是这里存在一个问题,那就是当服务器关机重启的时候,服务不能随计算机的启动而自己启动,那么我们可以将tomcat服务设置为开机启动。 打开linux设置开启启动的文件,将下面的配置文件写入此文件的最后,命令为:

1
vim /etc/rc.d/rc.local
1
2
3
4
5
6
export JAVA_HOME=/usr/local/jdk1.8.0_121
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin
export CATALINA_HOME=/usr/local/apache-tomcat-8.5.13
#tomcat自启动
/usr/local/apache-tomcat-8.5.11/bin/startup.sh

tomcat依赖于Java的jdk,所以设置的时候讲jdk也同步导入。 完成上面的步骤之后我们就可以将centos关机重启检查一番。

引用: 1.Linux(Centos)之安装Java JDK及注意事项 2.Linux(Centos)之安装tomcat并且部署Java Web项目

##一.卸载mariadb

列出所有被安装的rpm package

1
2
3
4
rpm -qa | grep mariadb
mariadb-libs-5.5.50-1.el7_2.x86_64
mariadb-5.5.50-1.el7_2.x86_64
mariadb-server-5.5.50-1.el7_2.x86_64

卸载

1
rpm -e mariadb-libs-5.5.50-1.el7_2.x86_64

此时报错:

1
2
3
4
5
6
7
8
9
error: Failed dependencies:
libmysqlclient.so.18()(64bit) is needed by (installed) postfix-2:2.10.1-6.el7.x86_64
libmysqlclient.so.18()(64bit) is needed by (installed) perl-DBD-MySQL-4.023-5.el7.x86_64
libmysqlclient.so.18()(64bit) is needed by (installed) php-mysql-5.4.16-36.3.el7_2.x86_64
libmysqlclient.so.18(libmysqlclient_18)(64bit) is needed by (installed) postfix-2:2.10.1-6.el7.x86_64
libmysqlclient.so.18(libmysqlclient_18)(64bit) is needed by (installed) perl-DBD-MySQL-4.023-5.el7.x86_64
libmysqlclient.so.18(libmysqlclient_18)(64bit) is needed by (installed) php-mysql-5.4.16-36.3.el7_2.x86_64
mariadb-libs(x86-64) = 1:5.5.50-1.el7_2 is needed by (installed) mariadb-1:5.5.50-1.el7_2.x86_64
mariadb-libs(x86-64) = 1:5.5.50-1.el7_2 is needed by (installed) mariadb-server-1:5.5.50-1.el7_2.x86_64

强制卸载,因为没有–nodeps

1
2
3
rpm -e --nodeps mariadb-libs-5.5.50-1.el7_2.x86_64
rpm -e --nodeps mariadb-5.5.50-1.el7_2.x86_64
rpm -e --nodeps mariadb-server-5.5.50-1.el7_2.x86_64

然后可以安装MySQL了。

##二.安装MySQL

CentOS 7的yum源中貌似没有正常安装mysql时的mysql-sever文件,需要去官网上下载.传送门: http://dev.mysql.com/downloads/repo/yum/

选择 Red Hat Enterprise Linux 7 / Oracle Linux 7 (Architecture Independent), RPM Package, Download. 得到地址 http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

1
2
3
wget http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
rpm -ivh mysql57-community-release-el7-9.noarch.rpm
yum install mysql-community-server

成功安装之后初始化MySQL

1
mysqld --initialize

mysql5.7会生成一个初始化密码,而在之前的版本首次登陆不需要登录。

搜索MySQL的日志文件

1
2
cat /var/log/mysqld.log | grep A temporary password is generated for root@localhost
2017-01-20 16:46:53.059632Z 1 [Note] A temporary password is generated for root@localhost: +wGVA#to(4tu

用上面的+wGVA#to(4tu就可以登录了

1
mysql -uroot -p+wGVA#to(4tu

重置密码,执行以下SQL语句

1
2
set password for 'root'@'localhost'=password('newpassword');
set password for 'root'@'%'=password('newpassword');

开启远程访问,执行以下SQL语句,其中password为数据库账户密码

1
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;

刷新数据

1
FLUSH PRIVILEGES;

##后续

最近在一台阿里云CentOS 7 64位服务器上安装MySQL,无论如何都找不到自动生成的密钥,重新安装几次无果后,由于是新安装,于是直接将

1
rm -rf /var/lib/mysql

文件夹删除,用初始化命令,重新初始化.

1
mysqld --initialize

最终获取控制台输出的密码:

1
2017-02-20T14:45:06.344885Z 1 [Note] A temporary password is generated for root@localhost: 5;4f5k(xgc1T

但这个时候出现一个新的问题,mysqld服务无法启动

1
service mysqld start

出错

1
2
Redirecting to /bin/systemctl start mysqld.service
Job for mysqld.service failed because the control process exited with error code. See "systemctl status mysqld.service" and "journalctl -xe" for details.

使用命令

1
systemctl status mysqld.service

1
journalctl -xe

输出

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
mysqld.service - MySQL Server
Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)
Active: failed (Result: start-limit) since Mon 2017-02-20 22:39:07 CST; 41s ago
Docs: man:mysqld(8)
http://dev.mysql.com/doc/refman/en/using-systemd.html
Process: 1216 ExecStart=/usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid $MYSQLD_OPTS (code=exited, status=1/FAILURE)
Process: 1199 ExecStartPre=/usr/bin/mysqld_pre_systemd (code=exited, status=0/SUCCESS)
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Failed to start MySQL Server.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Unit mysqld.service entered failed state.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service failed.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service holdoff time over, scheduling restart.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: start request repeated too quickly for mysqld.service
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Failed to start MySQL Server.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Unit mysqld.service entered failed state.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service failed.
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit mysqld.service has begun starting up.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: mysqld: Can't change dir to '/var/lib/mysql/' (Errcode: 13 - Permission denied)
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.471602Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.471725Z 0 [Warning] 'NO_ZERO_DATE', 'NO_ZERO_IN_DATE' and 'ERROR_FOR_DIVISION_BY_ZERO' sql modes should be used with strict mode. They will be merged
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.471730Z 0 [Warning] 'NO_AUTO_CREATE_USER' sql mode was not set.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.476447Z 0 [Warning] Can't create test file /var/lib/mysql/iZbp1bmnc8vn2gk235cg4dZ.lower-test
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.476503Z 0 [Note] /usr/sbin/mysqld (mysqld 5.7.17) starting as process 1220 ...
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.493302Z 0 [Warning] Can't create test file /var/lib/mysql/iZbp1bmnc8vn2gk235cg4dZ.lower-test
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.493827Z 0 [Warning] Can't create test file /var/lib/mysql/iZbp1bmnc8vn2gk235cg4dZ.lower-test
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.494310Z 0 [ERROR] failed to set datadir to /var/lib/mysql/
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.495364Z 0 [ERROR] Aborting
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service: control process exited, code=exited status=1
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: Initialization of mysqld failed: 0
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.497018Z 0 [Note] Binlog end
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: 2017-02-20T14:39:07.497183Z 0 [Note] /usr/sbin/mysqld: Shutdown complete
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Failed to start MySQL Server.
-- Subject: Unit mysqld.service has failed
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit mysqld.service has failed.
--
-- The result is failed.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Unit mysqld.service entered failed state.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service failed.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service holdoff time over, scheduling restart.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: start request repeated too quickly for mysqld.service
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Failed to start MySQL Server.
-- Subject: Unit mysqld.service has failed
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit mysqld.service has failed.
--
-- The result is failed.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: Unit mysqld.service entered failed state.
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ systemd[1]: mysqld.service failed.

注意这一行

1
Feb 20 22:39:07 iZbp1bmnc8vn2gk235cg4dZ mysqld[1216]: mysqld: Can't change dir to '/var/lib/mysql/' (Errcode: 13 - Permission denied)

权限问题导致mysql.lock写不了

1
chmod 777 -R /var/lib/mysql

OK,故障解除!

曾经使用了两年多的Vim,手册也翻过一遍。虽然现在不怎么用vim了,曾经的笔记还是贴出来,与喜欢vim的朋友分享。

阅读全文 »

image

1.缓存

2.图片加载

3.图片处理

4.网络请求

  • Android Async HTTP Android异步HTTP库
  • AndroidAsync 异步Socket,HTTP(客户端+服务器),WebSocket,和socket.io库。基于NIO而不是线程。
  • OkHttp 一个Http与Http/2的客户端
  • Retrofit 类型安全的Http客户端
  • Volley Google推出的Android异步网络请求框架和图片加载框架

5.网络解析

  • Gson 一个Java序列化/反序列化库,可以将JSON和java对象互相转换
  • Jackson Jackson可以轻松地将Java对象转换成json对象和xml文档,同样也可以将json、xml转换成Java对象
  • Fastjson Java上一个快速的JSON解析器/生成器
  • HtmlPaser 一种用来解析单个独立html或嵌套html的方式
  • Jsoup 一个以最好的DOM,CSS和jQuery解析html的库

6.数据库

  • OrmLite JDBC和Android的轻量级ORM java包
  • Sugar 用超级简单的方法处理Android数据库
  • GreenDAO 一种轻快地将对象映射到SQLite数据库的ORM解决方案
  • ActiveAndroid 以活动记录方式为Android SQLite提供持久化
  • SQLBrite SQLiteOpenHelper 和ContentResolver的轻量级包装
  • Realm 移动数据库:一个SQLite和ORM的替换品

7.依赖注入

8.图表

9.后台处理

10.事件总线

  • EventBus 安卓优化的事件总线,简化了活动、片段、线程、服务等的通信
  • Otto 一个基于Guava的增强的事件总线

11.响应式编程

  • RxJava JVM上的响应式扩展
  • RxJavaJoins 为RxJava提供Joins操作
  • RxAndroid Android上的响应式扩展,在RxJava基础上添加了Android线程调度
  • RxBinding 提供用RxJava绑定Android UI的API
  • Agera Android上的响应式编程

12.Log框架

  • Logger 简单,漂亮,强大的Android日志工具
  • Hugo 在调试版本上注解的触发方法进行日志记录
  • Timber 一个小的,可扩展的日志工具

13.测试框架

  • Mockito Java编写的Mocking单元测试框架
  • Robotium Android UI 测试
  • Robolectric Android单元测试框架
  • Android自带很多测试工具:JUnit,Monkeyrunner,UiAutomator,Espresso等

14.调试框架

  • Stetho 调试Android应用的桥梁,使得可以利用Chrome开发者工具进行调试

15.性能优化

  • LeakCanary 内存泄漏检测工具
  • ACRA Android应用程序崩溃报告

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
color 0a
@echo off
mode con: cols=50 lines=25
title MySQL 数据导入导出脚本
set ip=127.0.0.1
set dk=3306
set user=root
set pass=123456
set db=null
set file=null
:a
cls
echo.
echo ╔─╣【MySQL 数据导入导出脚本】╠─╗
echo │ 1.导出数据 │ 2.导入数据 │
echo ╚────────╩────────╝
echo Q 退出
echo.
echo ■使用指南
echo ◇ 导出数据默认保存于当前目录,文件名为导
echo出操作时的日期加时间,后缀名为sql的文件.
echo.
echo ◇ 导入数据文件可直接拖放入本窗口,一次只
echo能操作一个文件.导入操作不可逆转,存在数
echo据覆盖风险,请确认SQL文件的作用域,误导
echo入造成数据损毁作者概不负责.
echo.
echo ◇ 请确保MySQL的bin目录在操作系统环境变量
echo"path"中,否则请将此脚本置于MySQL安装目
echo录bin目录下运行.
echo.
echoBy:Liux QQ^&EMail:lx0758@qq.com
echo.
set /p xx=请输入选项后按Enter(1/2/Q):
cls
if %xx%==1 goto aaa
if %xx%==2 goto bbb
if /i %xx%==Q exit
echo 输入有误!按任意键返回...& pause>nul 2>nul
goto a
:aaa
echo 输入IP地址[%ip%]:
set /p ip=
echo.
echo 输入端口[%dk%]:
set /p dk=
echo.
echo 输入账户名[%user%]:
set /p user=
echo.
echo 输入密钥[%pass%]:
set /p pass=
echo.
echo 输入要导出的库名称("-A"表示全部库)[%db%]:
set /p db=
cls
echo 请确认信息:
echo.
echo 数据库地址及地址:%ip%:%dk%
echo.
echo 数据库账户:%user%
echo 数据库口令:%pass%
echo.
echo 导出数据库名称:%db%
echo.
set /p qr= 操作不可逆,确认操作?(Y/N):
if /i not %qr%==Y goto z
cls
set dt=%date:~0,10%_%time:~0,8%
set "dt=%dt:/=%"
set "dt=%dt::=%"
echo.
echo 正在处理,如出现确认密码请输入密码确认!
echo.
mysqldump -u%user% -p%pass% -h%ip% -P%dk% %db% > %db%_%dt%.sql
echo.
echo 执行完毕!任意键继续. & pause>nul 2>nul
goto a
:bbb
echo 输入IP地址[%ip%]:
set /p ip=
echo.
echo 输入端口[%dk%]:
set /p dk=
echo.
echo 输入账户名[%user%]:
set /p user=
echo.
echo 输入密钥[%pass%]:
set /p pass=
echo.
echo 输入要导入的库名称("-A"表示全部库)[%db%]:
set /p db=
echo.
echo 拖入需要导入的SQL文件[%file%]:
set /p file=
cls
echo.
echo 请确认信息:
echo.
echo 数据库地址及地址:%ip%:%dk%
echo.
echo 数据库账户:%user%
echo 数据库口令:%pass%
echo.
echo 导入数据库名称:%db%
echo 导入文件的路径:%file%
echo.
echo.
set /p qr= 操作不可逆,确认操作?(Y/N):
if /i not %qr%==Y goto z
cls
echo 正在处理,如出现确认密码请输入密码确认!
echo.
mysql -u%user% -p%pass% -h%ip% -P%dk% %db% < "%file%"
echo.
echo 执行完毕!任意键继续. & pause>nul 2>nul
goto a
:z
echo.
echo 操作终止!任意键继续. & pause>nul 2>nul
goto a

一、站点版

(一)、企业站

  1. 搜狐:http://mirrors.sohu.com/
  2. 网易:http://mirrors.163.com/
  3. 阿里云:http://mirrors.aliyun.com/
  4. 腾讯:http://android-mirror.bugly.qq.com:8080/ (仅针对APP开发的软件,限流,不推荐)

(二)、教育站

  1. 上海交通大学:http://ftp.sjtu.edu.cn/html/resources.xml (部分移动运营商出口状况不佳,无法访问)
  2. 华中科技大学:http://mirror.hust.edu.cn/ (当前已用容量估计:4.83T)
  3. 清华大学:http://mirrors.tuna.tsinghua.edu.cn/ (当前已用容量估计:9.8T)
  4. 北京理工大学:http://mirror.bit.edu.cn/web/
  5. 兰州大学:http://mirror.lzu.edu.cn/
  6. 中国科技大学:http://mirrors.ustc.edu.cn/ (当前已用容量估计:21.32T)
  7. 大连东软信息学院:http://mirrors.neusoft.edu.cn/ (当前已用容量估计:2.5T)
  8. 东北大学:http://mirror.neu.edu.cn/
  9. 大连理工大学:http://mirror.dlut.edu.cn/
  10. 哈尔滨工业大学:http://run.hit.edu.cn/html/ (部分联通运营商出口状况不佳,无法访问)
  11. 北京交通大学:http://mirror.bjtu.edu.cn/cn/
  12. 天津大学:http://mirror.tju.edu.cn (无法访问,ping超时)
  13. 中国地质大学:http://mirrors.cug.edu.cn/ (当前已用容量估计:2.3T)
  14. 浙江大学:http://mirrors.zju.edu.cn/
  15. 厦门大学:http://mirrors.xmu.edu.cn/
  16. 中山大学:http://mirror.sysu.edu.cn/
  17. 重庆大学:http://mirrors.cqu.edu.cn/ (当前已用容量估计:3.93T)
  18. 北京化工大学:http://ubuntu.buct.edu.cn/ (Android SDK镜像仅供校内使用,当前已用容量估计:1.72T)
  19. 南阳理工学院:http://mirror.nyist.edu.cn/
  20. 中国科学院:http://www.opencas.org/mirrors/
  21. 电子科技大学:http://ubuntu.uestc.edu.cn/ (无法访问,ping超时)
  22. 电子科技大学星辰工作室:http://mirrors.stuhome.net/ (当前已用容量估计:1.08T)
  23. 西北农林科技大学:http://mirrors.nwsuaf.edu.cn/ (只做CentOS镜像,当前已用容量估计:140GB)

(三)、其他

  1. 首都在线科技股份有限公司(英文名Capital Online Data Service):http://mirrors.yun-idc.com/
  2. 中国电信天翼云:http://mirrors.ctyun.cn/
  3. noc.im:http://mirrors.noc.im/ (当前已用容量估计:3.74T)
  4. 常州贝特康姆软件技术有限公司:http://centos.bitcomm.cn/ (只做CentOS镜像,当前已用容量估计:140GB)
  5. 公云PubYun(母公司为贝特康姆):http://mirrors.pubyun.com/
  6. Linux运维派:http://mirrors.skyshe.cn/ (使用阿里云服务器,界面使用浙江大学的模板,首页维护,内容可访问)
  7. 中国互联网络信息中心:http://mirrors.cnnic.cn/ (只做Apache镜像,当前已用容量估计:120GB)
  8. Fayea工作室:http://apache.fayea.com/ (只做Apache镜像,当前已用容量估计:120GB)

二、软件版

(一)、操作系统类

1.Ubuntu

  1. 阿里云:http://mirrors.aliyun.com/ubuntu-releases/
  2. 网易:http://mirrors.163.com/ubuntu-releases/
  3. 搜狐:http://mirrors.sohu.com/ubuntu-releases/ (搜狐在12年之后似乎不同步了)
  4. 首都在线科技股份有限公司:http://mirrors.yun-idc.com/ubuntu-releases/

2.CentOS

  1. 网易:http://mirrors.163.com/centos/
  2. 搜狐:http://mirrors.sohu.com/centos/
  3. 阿里云:http://mirrors.aliyun.com/centos/

(二)、服务器类

1.Tomcat、Apache

  1. 中国互联网络信息中心:http://mirrors.cnnic.cn/apache/
  2. 华中科技大学:http://mirrors.hust.edu.cn/apache/
  3. 北京理工大学:http://mirror.bit.edu.cn/apache/

2.MySQL

  1. 北京理工大学:http://mirror.bit.edu.cn/mysql/Downloads/
  2. 中国电信天翼云:http://mirrors.ctyun.cn/Mysql/

3.PostgreSQL

  1. 浙江大学:http://mirrors.zju.edu.cn/postgresql/

4.MariaDB

  1. 中国电信天翼云:http://mirrors.ctyun.cn/MariaDB/

5.VideoLAN

  1. 大连东软信息学院:http://mirrors.neusoft.edu.cn/videolan/
  2. 中国科技大学:http://mirrors.ustc.edu.cn/videolan-ftp/

(三)、开发工具类

1.Eclipse

  1. 中国科技大学:http://mirrors.ustc.edu.cn/eclipse/
  2. 中国科学院:http://mirrors.opencas.cn/eclipse/
  3. 东北大学:http://ftp.neu.edu.cn/mirrors/eclipse/,http://mirror.neu.edu.cn/eclipse/

2.Android

  1. 中国科学院:http://mirrors.opencas.ac.cn/android/repository/
  2. 南洋理工学院:http://mirror.nyist.edu.cn/android/repository/
  3. 中国科学院:http://mirrors.opencas.cn/android/repository/
  4. 腾讯:http://android-mirror.bugly.qq.com:8080/android/repository/ (限流,不推荐)
  5. 大连东软信息学院:http://mirrors.neusoft.edu.cn/android/repository/ (同步效果不如中科院的镜像,不推荐)

3.Xcode

  1. 腾讯:http://android-mirror.bugly.qq.com:8080/Xcode/ (从7.2之后不再更新,建议直接从官网下载)

网易云