Linux下搭建JavaWEB环境
标签(空格分隔): web
1.安装JDK8
首先使用wget下载jdk的安装包.这里下载tar.gz格式的.
wget http://download.oracle.com/otn-pub/java/jdk/8u102-b14/jdk-8u102-linux-x64.tar.gz?AuthParam=1476751964_f1dfd6d751c1ba8070fbb56a56e4e1db
然后修改文件名称
mv jdk-8u102-linux-x64.tar.gz\?AuthParam\=1476751964_f1dfd6d751c1ba8070fbb56a56e4e1db jdk8.tar.gz
在usr中创建java文件夹
mkdir /usr/java
复制jdk8.tar.gz到该文件夹
cp jdk8.tar.gz /usr/java
cd /usr/java
解压,并删除压缩包
tar xvf jdk8.tar.gz
rm jdk8.tar.gz
解压后,/usr/java下面就会有个jdk1.8的文件夹
配置环境变量
vi /etc/profile
//在文件末尾插入如下内容
export JAVA_HOME=/usr/java/jdk1.8.0_102
export JRE_HOME=$JAVA_HOME/jre
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=./:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
使配置生效
source /etc/profile
测试
java -version
有提示版本号即成功.
2.配置tomcat
tomcat和window下差不多,下载压缩包,解压后进入bin文件夹直接启动就好了.
3.配置mysql
下载rpm包
wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
更改名称
mv mysql-community-release-el7-5.noarch.rpm mysql5.7.rpm
安装rpm
sudo rpm -ivh mysql5.7.rpm
安装mysql
sudo yum install mysql-server
登录
mysql -u root
修改密码
use mysql;
update user set password=password('666666') where user='root';
允许远程访问
UPDATE user SET `Host` = '%' WHERE `User` = 'root' LIMIT 1;
flush privileges;
查看是否开启启动
systemctl is-enabled mysqld
如果未启动,则设置开机启动,这个只针对服务,上面安装mysql是以服务形式安装的.
systemctl enable mysqld
附录一些命令
启动一个服务:systemctl start postfix.service
关闭一个服务:systemctl stop postfix.service
重启一个服务:systemctl restart postfix.service
显示一个服务的状态:systemctl status postfix.service
在开机时启用一个服务:systemctl enable postfix.service
在开机时禁用一个服务:systemctl disable postfix.service
查看服务是否开机启动:systemctl is-enabled postfix.service;echo $?
查看已启动的服务列表:systemctl list-unit-files|grep enabled
这里我碰到了允许远程访问后,本地账户root就登录上去后,看不到mysql表了.
mysql>show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
+--------------------+
只显示这个两个数据库,看不到mysql数据库
第一种解决方法:
此问题实际上是用户没有权限:
1. 关闭mysql,service mysqld stop
2. 启动mysql: mysqld_safe --skip-grant-tables
3. 再打开一个ssh连接服务器,进行mysql操作
[root@localhost ~]#mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 7
Server version: 5.0.77 Source distribution
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql>show databases;
在这个模式下是可以看到mysql数据库的。
在数据库名mysql下的user表中,修改相应权限,比如:
INSERT INTO `user` VALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);
如果已经存在了host为localhost的记录,则先删除该记录,delete from user where host='localhost';
然后再进行INSERT INTO `user` VALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);
操作。
操作完成后,将两个ssh连接都关闭,然后再重新连接一个ssh,启动mysql,service mysqld start,然后用mysql命令连接mysql数据库
[root@localhost ~]#mysql -uroot -p
密码为空。
[如果此时还连接不上,再重启一下mysql就好了,service mysqld restart]。
然后就可以用 [root@localhost ~]#mysqladmin -uroot password 'newpassword' 来设置密码了。
第二种解决方法:
1.首先停止mysql服务:service mysqld stop
2.加参数启动mysql:/usr/bin/mysqld_safe --skip-grant-tables &
然后就可以无任何限制的访问mysql了
3.root用户登陆系统:mysql -u root -p mysql
4.切换数据库:use mysql
5.显示所有的表:show tables;
这里就可以访问表了
6.查看user表中root用户的localhost权限:select * from user where user='root' and host='localhost'
7.在显示的列表中显示:root用户的localhost的权限都是'N',表示root用户本地登陆不具有权限
8.修改root用户的localhost权限:
update user set
`Select_priv` = 'Y',
`Insert_priv` = 'Y',
`Update_priv` = 'Y',
`Delete_priv` = 'Y',
`Create_priv` = 'Y',
`Drop_priv` = 'Y',
`Reload_priv` = 'Y',
`Shutdown_priv` = 'Y',
`Process_priv` = 'Y',
`File_priv` = 'Y',
`Grant_priv` = 'Y',
`References_priv` = 'Y',
`Index_priv` = 'Y',
`Alter_priv` = 'Y',
`Show_db_priv` = 'Y',
`Super_priv` = 'Y',
`Create_tmp_table_priv` = 'Y',
`Lock_tables_priv` = 'Y',
`Execute_priv` = 'Y',
`Repl_slave_priv` = 'Y',
`Repl_client_priv` = 'Y',
`Create_view_priv` = 'Y',
`Show_view_priv` = 'Y',
`Create_routine_priv` = 'Y',
`Alter_routine_priv` = 'Y',
`Create_user_priv` = 'Y',
`Event_priv` = 'Y',
`Trigger_priv` = 'Y'
where user='root' and host='localhost' //这里需注意是否有这个条件的用户
9.更新一下:flush privileges;
10.然后重新启动下mysql,可以解决问题了
解决方法参考: http://blog.csdn.net/liuyifeng1920/article/details/49818851