朱杰兵blog

jonhney'blog
posts - 110, comments - 1, trackbacks - 0, articles - 0

2017年3月27日

最近在研究dubbo,避免不了从最简单的开始。按照网上教程启动zookeeper,启动tomcat时总是报错,

ERROR context.ContextLoader - Context initialization failed org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'uriBrokerService': Cannot create inner bean '(inner bean)' of type [com.alibaba.citrus.service.uribroker.impl.URIBrokerServiceImpl$URIBrokerInfo] while setting bean property 'brokers' with key [0]; nested excepti on is org.springframework.beans.factory.BeanCreationException: Error creating bean with name '(inner bean)#25': Cannot create inner bean 'server' of type [com.alibaba.citrus.service.uribroker.uri.GenericURIBroker] while setting constructor argument; nested exception is org.springframework.beans.fact ory.BeanCreationException: Error creating bean with name 'server': Error setting property values; nested exception is org.springframework.beans.NotWritablePropertyException: Invalid property 'URIType' of bean class [com.alibaba.citrus.service.uribroker.uri.GenericURIBroker]: Bean property 'URIType' is not writable or has an invalid setter method. Does the parameter type of the setter match the return type of the getter?         at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveInnerBean(BeanDefinitionValueResolver.java:230)         at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:122)         at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveManagedList(BeanDefinitionValueResolver.java:287)

查了很久,终于发现问题所在,现在记录下


原来是我用的jdk版本太高,jdk8, dubbo默认用的spring版本比较旧,冲突导致,降低jdk版本为1.7即可

posted @ 2017-03-27 00:44 朱杰兵 阅读(12) | 评论 (0)编辑 收藏

2017年3月20日

Linux下在防火墙中开启80端口、3306端口的方法
vi /etc/sysconfig/iptables

-A INPUT -m state –state NEW -m tcp -p tcp –dport 80 -j ACCEPT(允许80端口通过防火墙)
-A INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT(允许3306端口通过防火墙)
特别提示:很多网友把这两条规则添加到防火墙配置的最后一行,导致防火墙启动失败,正确的应该是添加到默认的22端口这条规则的下面

添加好之后防火墙规则如下所示:
代码如下:
# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -m state –state ESTABLISHED,RELATED -j ACCEPT
-A INPUT -p icmp -j ACCEPT
-A INPUT -i lo -j ACCEPT
-A INPUT -m state –state NEW -m tcp -p tcp –dport 22 -j ACCEPT
-A INPUT -m state –state NEW -m tcp -p tcp –dport 80 -j ACCEPT
-A INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT
-A INPUT -j REJECT –reject-with icmp-host-prohibited
-A FORWARD -j REJECT –reject-with icmp-host-prohibited
COMMIT


然后重启一下防火墙

service iptables restart

搞定!

posted @ 2017-03-20 15:54 朱杰兵 阅读(10) | 评论 (0)编辑 收藏

此时我们就可以通过 mysql -u root -p 命令来登录我们的mysql数据库了
授权法。

例如,你想用户root使用密码root从任何主机连接到mysql服务器的话。

先执行

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

再执行

mysql>FLUSH   PRIVILEGES;         
使修改生效

posted @ 2017-03-20 15:26 朱杰兵 阅读(7) | 评论 (0)编辑 收藏

Linux下mysql安装完后是默认:区分表名的大小写,不区分列名的大小写;
用root帐号登录后,在/etc/my.cnf中的[mysqld]后添加添加lower_case_table_names=1,重启MYSQL服务,这时已设置成功:不区分表名的大小写;
lower_case_table_names参数详解:
lower_case_table_names=0
其中0:区分大小写,1:不区分大小写

posted @ 2017-03-20 15:23 朱杰兵 阅读(11) | 评论 (0)编辑 收藏

转载自

http://www.centoscn.com/mysql/2014/1211/4290.html

一、mysql简介

说到数据库,我们大多想到的是关系型数据库,比如mysql、oracle、sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库,咱不得不首先推荐的是mysql数据库了,而且Mysql数据库的第一个版本就是发行在Linux系统上的。

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL的SQL语言是用于访问数据库的最常用标准化语言。MySQL软件采用了双授权政策(本词条“授权政策”),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。由于其社区版的性能卓越,搭配PHP和Apache可组成良好的开发环境。

在Linux上安装mysql数据库,我们可以去其官网上下载mysql数据库的rpm包,http://dev.mysql.com/downloads/mysql/5.6.html#downloads,大家可以根据自己的操作系统去下载对应的数据库文件,目前最新的版本是5.6.10了。

在这里我是通过yum来进行mysql数据库的安装的,通过这种方式进行安装,可以将跟mysql相关的一些服务、jar包都给我们安装好,所以省去了很多不必要的麻烦!!!

二、卸载掉原有mysql

因为mysql数据库在Linux上实在是太流行了,所以目前下载的主流Linux系统版本基本上都集成了mysql数据库在里面,我们可以通过如下命令来查看我们的操作系统上是否已经安装了mysql数据库

[root@xiaoluo ~]# rpm -qa | grep mysql  // 这个命令就会查看该操作系统上是否已经安装了mysql数据库

有的话,我们就通过 rpm -e 命令 或者 rpm -e --nodeps 命令来卸载掉

[root@xiaoluo ~]# rpm -e mysql  // 普通删除模式 [root@xiaoluo ~]# rpm -e --nodeps mysql  // 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强力删除

在删除完以后我们可以通过 rpm -qa | grep mysql 命令来查看mysql是否已经卸载成功!!

三、通过yum来进行mysql的安装

我是通过yum的方式来进行mysql的数据库安装,首先我们可以输入 yum list | grep mysql 命令来查看yum上提供的mysql数据库可下载的版本:

[root@xiaoluo ~]# yum list | grep mysql

就可以得到yum服务器上mysql数据库的可下载版本信息:

 

 

然后我们可以通过输入 yum install -y mysql-server mysql mysql-devel 命令将mysql mysql-server mysql-devel都安装好(注意:安装mysql时我们并不是安装了mysql客户端就相当于安装好了mysql数据库了,我们还需要安装mysql-server服务端才行)

 

[root@xiaoluo ~]# yum install -y mysql-server mysql mysql-devel

 

在等待了一番时间后,yum会帮我们选择好安装mysql数据库所需要的软件以及其它附属的一些软件

 

 

我们发现,通过yum方式安装mysql数据库省去了很多没必要的麻烦,当出现下面的结果时,就代表mysql数据库安装成功了

 

 

此时我们可以通过如下命令,查看刚安装好的mysql-server的版本

 

[root@xiaoluo ~]# rpm -qi mysql-server

 

我们安装的mysql-server并不是最新版本,如果你想尝试最新版本,那就去mysql官网下载rpm包安装就行了,至此我们的mysql数据库已经安装完成了。

四、mysql数据库的初始化及相关配置

我们在安装完mysql数据库以后,会发现会多出一个mysqld的服务,这个就是咱们的数据库服务,我们通过输入 service mysqld start 命令就可以启动我们的mysql服务。

注意:如果我们是第一次启动mysql服务,mysql服务器首先会进行初始化的配置,如:

复制代码
[root@xiaoluo ~]# service mysqld start  初始化 MySQL 数据库: WARNING: The host 'xiaoluo' could not be looked up with resolveip. This probably means that your libc libraries are not 100 % compatible with this binary MySQL version. The MySQL daemon, mysqld, should work normally with the exception that host name resolving will not work. This means that you should use IP addresses instead of hostnames when specifying MySQL privileges ! Installing MySQL system tables... OK Filling help tables... OK  To start mysqld at boot time you have to copy support-files/mysql.server to the right place for your system  PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER ! To do so, start the server, then issue the following commands:  /usr/bin/mysqladmin -u root password 'new-password' /usr/bin/mysqladmin -u root -h xiaoluo password 'new-password'  Alternatively you can run: /usr/bin/mysql_secure_installation  which will also give you the option of removing the test databases and anonymous user created by default.  This is strongly recommended for production servers.  See the manual for more instructions.  You can start the MySQL daemon with: cd /usr ; /usr/bin/mysqld_safe &  You can test the MySQL daemon with mysql-test-run.pl cd /usr/mysql-test ; perl mysql-test-run.pl  Please report any problems with the /usr/bin/mysqlbug script!                                                             [确定] 正在启动 mysqld:                                            [确定]
复制代码

 

这时我们会看到第一次启动mysql服务器以后会提示非常多的信息,目的就是对mysql数据库进行初始化操作,当我们再次重新启动mysql服务时,就不会提示这么多信息了,如:

 

[root@xiaoluo ~]# service mysqld restart 停止 mysqld:                                             [确定] 正在启动 mysqld:                                          [确定]

 

我们在使用mysql数据库时,都得首先启动mysqld服务,我们可以 通过  chkconfig --list | grep mysqld 命令来查看mysql服务是不是开机自动启动,如:

 

[root@xiaoluo ~]# chkconfig --list | grep mysqld mysqld             0:关闭    1:关闭    2:关闭    3:关闭    4:关闭    5:关闭    6:关闭

 

我们发现mysqld服务并没有开机自动启动,我们当然可以通过 chkconfig mysqld on 命令来将其设置成开机启动,这样就不用每次都去手动启动了

 

[root@xiaoluo ~]# chkconfig mysqld on [root@xiaoluo ~]# chkconfig --list | grep mysql mysqld             0:关闭    1:关闭    2:启用    3:启用    4:启用    5:启用    6:关闭

 

mysql数据库安装完以后只会有一个root管理员账号,但是此时的root账号还并没有为其设置密码,在第一次启动mysql服务时,会进行数据库的一些初始化工作,在输出的一大串信息中,我们看到有这样一行信息 :

 

/usr/bin/mysqladmin -u root password 'new-password'  // 为root账号设置密码 

 

所以我们可以通过 该命令来给我们的root账号设置密码(注意这个root账号是mysql的root账号,非Linux的root账号)

 

[root@xiaoluo ~]# mysqladmin -u root password 'root'  // 通过该命令给root账号设置密码为 root

 

此时我们就可以通过 mysql -u root -p 命令来登录我们的mysql数据库了

 

五、mysql数据库的主要配置文件

1./etc/my.cnf 这是mysql的主配置文件

我们可以查看一下这个文件的一些信息

复制代码
[root@xiaoluo etc]# ls my.cnf  my.cnf  [root@xiaoluo etc]# cat my.cnf  [mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock user=mysql # Disabling symbolic-links is recommended to prevent assorted security risks symbolic-links=0  [mysqld_safe] log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid
复制代码

2./var/lib/mysql   mysql数据库的数据库文件存放位置

我们的mysql数据库的数据库文件通常是存放在了/ver/lib/mysql这个目录下

 

复制代码
[root@xiaoluo ~]# cd /var/lib/mysql/ [root@xiaoluo mysql]# ls -l 总用量 20488 -rw-rw----. 1 mysql mysql 10485760 4月   6 22:01 ibdata1 -rw-rw----. 1 mysql mysql  5242880 4月   6 22:01 ib_logfile0 -rw-rw----. 1 mysql mysql  5242880 4月   6 21:59 ib_logfile1 drwx------. 2 mysql mysql     4096 4月   6 21:59 mysql  // 这两个是mysql数据库安装时默认的两个数据库文件 srwxrwxrwx. 1 mysql mysql        0 4月   6 22:01 mysql.sock drwx------. 2 mysql mysql     4096 4月   6 21:59 test  // 这两个是mysql数据库安装时默认的两个数据库文件
复制代码

 

我们可以自己创建一个数据库,来验证一下该数据库文件的存放位置

 

复制代码
创建一个我们自己的数据库: mysql> create database xiaoluo; Query OK, 1 row affected (0.00 sec)  [root@xiaoluo mysql]# ls -l 总用量 20492 -rw-rw----. 1 mysql mysql 10485760 4月   6 22:01 ibdata1 -rw-rw----. 1 mysql mysql  5242880 4月   6 22:01 ib_logfile0 -rw-rw----. 1 mysql mysql  5242880 4月   6 21:59 ib_logfile1 drwx------. 2 mysql mysql     4096 4月   6 21:59 mysql srwxrwxrwx. 1 mysql mysql        0 4月   6 22:01 mysql.sock drwx------. 2 mysql mysql     4096 4月   6 21:59 test drwx------. 2 mysql mysql     4096 4月   6 22:15 xiaoluo  // 这个就是我们刚自己创建的xiaoluo数据库 [root@xiaoluo mysql]# cd xiaoluo/ [root@xiaoluo xiaoluo]# ls db.opt
复制代码

3./var/log mysql数据库的日志输出存放位置

我们的mysql数据库的一些日志输出存放位置都是在/var/log这个目录下

复制代码
[root@xiaoluo xiaoluo]# cd  [root@xiaoluo ~]# cd /var/log [root@xiaoluo log]# ls amanda                cron           maillog-20130331   spice-vdagent.log anaconda.ifcfg.log    cron-20130331  mcelog             spooler anaconda.log          cups           messages           spooler-20130331 anaconda.program.log  dirsrv         messages-20130331  sssd anaconda.storage.log  dmesg          mysqld.log         tallylog anaconda.syslog       dmesg.old      ntpstats           tomcat6 anaconda.xlog         dracut.log     piranha            wpa_supplicant.log anaconda.yum.log      gdm            pm-powersave.log   wtmp audit                 httpd          ppp                Xorg.0.log boot.log              ibacm.log      prelink            Xorg.0.log.old btmp                  lastlog        sa                 Xorg.1.log btmp-20130401         libvirt        samba              Xorg.2.log cluster               luci           secure             Xorg.9.log ConsoleKit            maillog        secure-20130331    yum.log
复制代码

 

其中mysqld.log 这个文件就是我们存放我们跟mysql数据库进行操作而产生的一些日志信息,通过查看该日志文件,我们可以从中获得很多信息

 

因为我们的mysql数据库是可以通过网络访问的,并不是一个单机版数据库,其中使用的协议是 tcp/ip 协议,我们都知道mysql数据库绑定的端口号是 3306 ,所以我们可以通过 netstat -anp 命令来查看一下,Linux系统是否在监听 3306 这个端口号:

结果如上所示,Linux系统监听的3306端口号就是我们的mysql数据库!!!!

posted @ 2017-03-20 15:21 朱杰兵 阅读(9) | 评论 (0)编辑 收藏

2017年3月7日

     摘要: run as --> run configuration  阅读全文

posted @ 2017-03-07 16:45 朱杰兵 阅读(16) | 评论 (0)编辑 收藏

2017年3月2日

1、下载源码,解压缩后编译源码。
$ wget http://download.redis.io/releases/redis-2.8.3.tar.gz 
$ tar xzf redis-2.8.3.tar.gz
$ cd redis
-2.8.3
$ make
make 的时候可能会遇到问题,
(1).缺少gcc,执行
yum -y install gcc ,解决
(2).error: jemalloc/jemalloc.h: No such file or directory解决方法
执行
make MALLOC=libc


2、编译完成后,在Src目录下,有三个可执行文件redis-server、redis-benchmark、redis-cli,以及根目录下有一个redis.conf。然后把这四个文件拷贝到一个目录下。
到src目录下执行命令
mkdir /usr/redis 
cp redis
-server /usr/redis
cp redis
-benchmark /usr/redis
cp redis
-cli /usr/redis
这里要切换到根目录
cp redis.conf
/usr/redis
cd
/usr/redis
3、启动Redis服务。
$ ./redis-server
会见到redis的logo
 4、然后用客户端测试一下是否启动成功。
$ ./redis-cli 
redis
> set foo bar
OK
redis
> get foo "bar"


-------------------------------------------------------------------------------------------------------------------------------
但是这样启动,如果关闭窗口,服务就会关闭
可为redis服务启动指定配置文件,配置文件 redis.conf 在Redis根目录下。
修改daemonize为yes,即默认以后台程序方式运行

这样就可以执行./redis-server ./redis.conf 进行后台启动

关闭redis服务 ./redis-cli shutdown

 

posted @ 2017-03-02 14:58 朱杰兵 阅读(22) | 评论 (0)编辑 收藏

2017年2月23日

今天学习在Linux上部署项目,用到了Mysql,因此想要下载适用于Linux的安装版本,在Mysql官网找了半天,终于找到怎样下载了,这里写出来,以后大家找的时候就好找了。
第一步:在百度输入Mysql,然后我们点击第一个链接,如下图所示。
第二步:点击上图的链接之后,我们会看到如下图所示的界面,我们点击“Download”子菜单中的"Community",如下图所示。
第三步:点击上图的"Community"之后,我们会看到如下图所示的界面,我们点击左侧菜单的"MySQL Community Server"。
第四步:点击上图左侧菜单中的"MySQL Community Server"之后,我们可以看到如下图所示的界面,默认是Windows系统下当前Mysql最高版本的安装包列表,如下图。

第五步:由于我们是要下载适合于Linux系统的.tar.gz类型的安装包,因此我们切换一下,我们切换成"Source Code",如下图所示。
      切换完之后,会看到如下图所示的界面,我们往下找,在倒数第二行有我们想要的mysql-5.7.16.tar.gz!!!我们下载就可以了。
     如果大家不想用最新版本的,想用5.6或5.5版本的,那么可以点击下图的"Looking for previous GA versions?"下面的"MySQL Community Server 5.6>"或"MySQLCommunity Server5.5>",然后Select Platform选择"Source Code",页面加载后在最后一行有我们想要的mysql-5.6.34.tar.gz安装包,我们就以下载mysql-5.6.34.tar.gz为例,我们点击它后面的"Download"按钮。如下图所示。
第六步:我们点击上图"mysql-5.6.34.tar.gz"后面的"Download"之后,会进入到如下图所示的界面,我们不注册,直接点击下面的“No thanks, just start my download.”链接,
第七步:点击上图的链接之后,便弹出下载对话框,我们点击“另存为”下载到我们想要的目录即可。

posted @ 2017-02-23 10:35 朱杰兵 阅读(19) | 评论 (0)编辑 收藏

2017年2月20日

进入超级用户模式。也就是输入"su -",系统会让你输入超级用户密码,输入密码后就进入了超级用户模式。

posted @ 2017-02-20 14:32 朱杰兵 阅读(17) | 评论 (0)编辑 收藏

2017年2月19日

vi /usr/profile

编辑完成后按esc键,并输入:wq 或者:x回车,就可以保存退出
如果不想保存,直接退出,则按下esc键,输入:q!,然后回车

一、插入文本
i  在当前字符前插入文本
I  在行首插入文本
a  在当前字符后添加文本 
A  在行末添加文本  
o  在当前行后面插入一空行 
O  在当前行前面插入一空行
二、移动光标
k、j、h、l——上、下、左、右光标移动命令。虽然您可以在Linux中使用键盘右边的4个光标键,但是记住这4个命令还是非常有用的。这4个键正是右手在键盘上放置的基本位置。
j或下箭头 向下移动一行  
k或上箭头 向上移动一行   
h或左箭头 左移一个字符  
l或右箭头 右移一个字符 

posted @ 2017-02-19 12:18 朱杰兵 阅读(24) | 评论 (0)编辑 收藏