0%

服务器采用的是Linux系统。

安装tomcat在服务器上后,客户端进入tomcat首页点击manager想进行项目管理发现没有登录提示,直接跳转403或401权限错误。

各方面资料调查后,发现这是tomcat8.5之后的版本,已经不支持远程登录,需要修改配置文件。

具体操作如下:

可以通过putty远程操作服务器修改,或者winscp远程修改文件。

文件地址/webapps/magager/META-INF/context.xml

原文为:

1
2
3
4
<Context antiResourceLocking="false" privileged="true" >
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
</Context>

改为:

1
2
3
4
5
6
<Context antiResourceLocking="false" privileged="true" >
<!--
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
-->
</Context>

##下载Redis

在Redis的官网下载页上有各种各样的版本,我这次是在windows上部署的,要去GitHub上下载。目前的是2.8.12版的,直接解压,在\bin\release 目录下有个压缩包,这就是我们需要的。 传送门:https://github.com/MicrosoftArchive/redis/releases

##启动Redis

直接在安装的目录打开命令窗口,运行:

1
redis-server redis.windows.conf

结果就悲剧了,提示:QForkMasterInit: system error caught. error code=0x000005af, message=VirtualAllocEx failed.: unknown error 。原因是内存分配的问题(如果你的电脑够强悍,可能不会出问题)。解决方法有两个,第一:启动的时候使用—maxmemory 命令限制Redis的内存:

1
redis-server redis.windows.conf --maxmemory 200m

第二种方法就是修改配置文件 redis.windows.conf ,修改以下节点:

1
maxmemory 209715200

注意单位是字节,改完后如下:

之后再运行下面的命令就可以启动了

1
redis-server redis.windows.conf

但是问题又来了,关闭cmd窗口就会关闭Redis,难道服务器上要一直开着吗?这显然是不科学的,下面看怎么在服务器上部署。 部署Redis

其实Redis是可以安装成windows服务的,开机自启动,命令如下:

1
redis-server --service-install redis.windows.conf

安装完之后,就可看到Redis已经作为windows服务了:

但是安装好之后,Redis并没有启动,启动命令如下:

1
redis-server --service-start

停止命令:

1
redis-server --service-stop

还可以安装多个实例

1
2
3
4
5
6
redis-server --service-install –service-name redisService1 –port 10001
redis-server --service-start –service-name redisService1
redis-server --service-install –service-name redisService2 –port 10002
redis-server --service-start –service-name redisService2
redis-server --service-install –service-name redisService3 –port 10003
redis-server --service-start –service-name redisService3

卸载命令:

1
redis-server --service-uninstall

最后提示一下:2.8版本的不支持32位系统,32位系统要去下载2.6版本的。2.6版本的无法像上面一样方便的部署,它提供一个叫RedisWatcher的程序来运行redis server,Redis停止后会自动重启。

在之前做了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