Fork me on GitHub
ookamiAntD's Blog

Ubuntu的Java开发环境基本搭建

前言

最近公司的电脑由于不明原因老是奔溃,重装过两次,在家里也比较喜欢折腾系统,为了不用每次都度娘谷歌,记录下来,一条龙走过。博主是搞爪哇开发的,那么以下搭建针对的是爪哇环境开发

安装JDK以及配置环境变量

安装JDK

安装之前当然是老规矩地下载jdkOracle JDK官方下载

1
2
3
4
5
6
7
# 把jdk的文件移动到 /usr/local/ 目录下
sudo mv ~/jdk*.tar.gz /usr/local/
# 解压文件
cd /usr/local/
# sudo tar -zxvf jdk-8u101-linux-x64.tar.gz
# 创建软链接
sudo ln -s jdk1.8.0_101 jdk

如需更换jdk,删除旧版本的软链接,重新创建软链接指向新版即可

1
2
sudo rm -rf jdk
sudo ln -s jdk* jdk

配置环境变量

  • 放到 /usr/local 里面的程序,建议使用系统变量。
  • 用户变量
    ~/.profile 文件是用户的私有配置文件
    ~/.bashrc 是在bash里面使用的私有配置文件,优先级在 .profile 文件之后
  • 系统变量
    /etc/profile 文件是系统的公用配置文件
    /etc/bash.bashrcbash专用的配置文件,优先级在 profile 文件之后
  • 系统变量的配置,不建议修改前面说到的两个文件,而是建议在 /etc/profile.d/ 目录下,创建一个 .sh 结尾 的文件。
1
sudo vi /etc/profile.d/jdk.sh

环境变量的配置内容如下:

  1. 设置一个名为JAVA_HOME的变量,并且使用export命令导出为环境变量, 如果不使用 export ,仅在当前shell里面有效

    1
    export JAVA_HOME=/usr/local/jdk
  2. PATH不需要export,因为早在其他的地方,已经export过了!,\$JAVA_HOME 表示引用前面配置的 JAVA_HOME 变量,分隔符一定是冒号,Windows是分号,最后再引用原来的PATH的值

    1
    PATH=$JAVA_HOME/bin:$PATH
  3. 配置以后,可以重新登录让配置生效,也可以使用source临时加载配置文件。使用source命令加载的配置,仅在当前shell有效,关闭以后失效。

    1
    source /etc/profile.d/jdk.sh
  4. 查看jdk是否安装成功,一下两条命令成功则安装成功

    1
    2
    java -version
    javac -version

安装Scala环境

更上面安装JDK类似

1、去 官网 下载最新地SDK

2、解压到 /usr/local 目录,并创建软链接为 scala

3、在 /etc/profile.d 目录下创建 scala.sh ,输入以下信息:

1
2
export SCALA_HOME=/usr/local/scala
PATH=$PATH:$SCALA_HOME/bin

4、查看是否安装成功

1
2
source /etc/profile.d/scala.sh
scala -version

安装IDE

Eclipse

直接在 Eclipse官方网站 下载相关版本Eclipse
解压

1
sudo tar zxvf eclipse-jee-mars-2-linux-gtk-x86_64.tar.gz -C ~/IDE

创建快捷方式
1. 在终端中执行如下命令

1
sudo gedit /usr/share/applications/eclipse.desktop

2. 粘贴并保存如下内容(注意更改相应的名字和目录)

1
2
3
4
5
6
7
8
9
10
[Desktop Entry] 
Name=Eclipse Mars.2
Type=Application
Exec=/home/ybd/IDE/eclipse
Terminal=false
Icon=/home/ybd/IDE/icon.xpm
Comment=Integrated Development Environment
NoDisplay=false
Categories=Development;IDE;
Name[en]=Eclipse Mars.2

通用设置
window → preferences →

  • 设置字体:general → appearance → color and font → basic → text font
  • 编辑器背景颜色:general → editors → text editors → background color → RGB:85,123,208,#C7EDCC
  • 工作空间字符编码:general → workspace
  • 作者签名:java → code style → code templates → types 签名快捷键:alt + shift + j

MyEclipse

MyEclipse安装请看:Ubuntu16.04下MyEclipse安装与破解

IntelliJ IDEA

之前听说过IDE[1],都是大公司用的,并没有用过
日后再研究补上
官网:http://www.jetbrains.com/idea/

新公司好多大牛,用的都是IDEA,于是乎“近墨者黑”,那么既然有机会跟大牛接触,我也开始真正意义上的学习IDEA了

安装

进过查阅,我选择官方的盒子下载:http://www.jetbrains.com/toolbox/app/?fromMenu
优点是可以自动更新

激活

博主使用授权服务器,可以自己搭建,详情请看 这里

部署Tomcat

若是服务器版切换root用户解压到 /opt/ 或者 /usr/local/
直接运行tomcat目录下bin/start.sh即可开启,前提是配置好JDK

桌面版个人使用就解压到/home/{user}目录下就可以了

安装MySQL以及GUI工具

mysql5.7以上版本为例 –> mysql-5.7.10-linux-glibc2.5-x86_64.tar.gz

必须要先安装依赖的libaio才能正常按照mysql

1
2
sudo apt-get update
sudo apt-get install libaio-dev

创建用户组以及用户

1
2
sudo groupadd mysql
sudo useradd -r -g mysql -s /bin/false mysql

尽量把mysql安装到/usr/local目录下面

1
2
3
4
5
6
cd /usr/local
sudo cp /home/data/software/DataBase/mysql/mysql-5.7.10-linux-glibc2.5-x86_64.tar.gz ./
<-- 解压缩安装包 -->
sudo tar zxvf mysql-5.7.10-linux-glibc2.5-x86_64.tar.gz
<-- 创建软连接 -->
sudo ln -s mysql-5.7.10-linux-glibc2.5-x86_64 mysql

创建必须的目录和进行授权

1
2
3
4
5
cd mysql
sudo mkdir mysql-files
sudo chmod 770 mysql-files
sudo chown -R mysql .
sudo chgrp -R mysql .

执行安装脚本

1
2
sudo bin/mysqld --initialize --user=mysql   
sudo bin/mysql_ssl_rsa_setup

在初始化的时候,一定要仔细看屏幕,最后大概有一行:[Note] A temporary password is generated for root@localhost: kklNBwkei1.t
注意这是root的临时密码,记录下来以便后面修改密码!

重新对一些主要的目录进行授权,确保安全性

1
2
sudo chown -R root .
sudo chown -R mysql data mysql-files

从默认的模板创建配置文件,需要在文件中增加 skip-grant-tables ,以便启动mysql以后修改root用户的密码

1
sudo cp support-files/my-default.cnf ./my.cnf

测试启动,修改密码

1
2
3
4
# 后台启动mysql
sudo bin/mysqld_safe --user=mysql &
# 启动
./bin/mysql -u root -p

方式一

因为前面修改了my.cnf文件,增加了 skip-grant-tables 参数,所以不需要用户名即可登陆
进去后立即修改root用户的密码,密码的字段是 authentication_string

1
update mysql.user set authentication_string=password('root') where user='root';

修改密码后,再把my.cnf里面的 skip-grant-tables 去掉

方式二

修改密码也可以使用安装到时候提示到随机密码进行登录,然后使用下面到命令修改密码。
建议用下面的方式设置数据库的密码

1
alter user user() identified by 'root';

复制启动脚本到合适的位置

1
sudo cp support-files/mysql.server /etc/init.d/mysql

(Optional)增加自动启动

1
sudo update-rc.d -f mysql defaults

增加mysql命令的路径到PATH环境变量

1
2
3
4
sudo touch /etc/profile.d/mysql.sh
sudo chmod 777 /etc/profile.d/mysql.sh
sudo echo "PATH=/usr/local/mysql/bin:\$PATH" > /etc/profile.d/mysql.sh
sudo chmod 644 /etc/profile.d/mysql.sh

到此,mysql的安装基本完成

修复乱码以及忽略大小写,找到MySQL文件里的my.cnf在末尾添加

1
2
lower_case_table_names=1
character_set_server=utf8

查看以及修改MySQL字符编码

查看

1
2
3
mysql> show variables like 'collation_%';

mysql> show variables like 'character_set_%';

修改

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
mysql> set character_set_client=utf8;
Query OK, 0 rows affected (0.00 sec)

mysql> set character_set_connection=utf8;
Query OK, 0 rows affected (0.00 sec)

mysql> set character_set_database=utf8;
Query OK, 0 rows affected (0.00 sec)

mysql> set character_set_results=utf8;
Query OK, 0 rows affected (0.00 sec)

mysql> set character_set_server=utf8;
Query OK, 0 rows affected (0.00 sec)

mysql> set character_set_system=utf8;
Query OK, 0 rows affected (0.01 sec)

mysql> set collation_connection=utf8_general_ci;
Query OK, 0 rows affected (0.01 sec)

mysql> set collation_database=utf8mb4_general_ci;
Query OK, 0 rows affected (0.01 sec)

mysql> set collation_server=utf8mb4_general_ci;
Query OK, 0 rows affected (0.01 sec)

如果登录mysql出现以下错误


则可能配置未加载或服务未启动,请重启系统,然后启动mysql服务

1
sudo service mysql start

结束mysql服务

1
sudo service mysql stop

开启远程链接

链接mysql后:

1
2
3
4
5
6
7
8
use mysql

// 下面两个root分别是帐号密码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
// 刷新特权
flush privileges;
// 查看修改是否成功
select host,user from user;

附加:基于Docker

拉取镜像

1
docker pull mysql:5.7

运行实例

1
MYSQL=/home/ybd/data/docker/mysql && docker run --name=mysql -p 3306:3306  -v $MYSQL/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --sql-mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION --lower-case-table-names=1

终端客户端

1
2
3
4
sudo apt-get install mysql-client

// 链接
mysql -h 127.0.0.1 -P 3306 -u root -p

安装Navicat For Mysql

官网下载对应系统版本
解压到适应文件夹
解压后,进入解压后的目录运行命令:

1
./start_navicat

OK,这样就完啦
连接上数据库后里面的中文数据是乱码,把Ubuntu的字符集修改为zh_CN.utf8就行了,修改方法:
1.查看系统支持的字符集: locale -a
2.到start_navicat修改字符集: export LANG=zh_CN.utf8

破解方案

懒人式破解

第一次执行start_navicat时,会在用户主目录下生成一个名为.navicat的隐藏文件夹。

1
cd /home/ybd/.navicat/

此文件夹下有一个system.reg文件

1
rm system.reg

把此文件删除后,下次启动navicat 会重新生成此文件,15天试用期会按新的时间开始计算。
这个是最简单暴力的方法!不过也是最麻烦的,因为每次到期删除了文件,再重新试用所有的配置。

完全破解

这个方法对Navicat For Mysql和Premium都有效,但貌似只能对111版本起效,其他更高版本需要另找锤子。
Download Now

点击上面跳到云盘,里面有111版的Navicat解压文件(Ubuntu版的),还有一个PatchNavicat.exe,把压缩包解压出来,然后照上面的安装,完成后把里面的Navicat.exe拷贝到windows虚拟机(博主用的VirtualBox),然后在虚拟机里面打开PatchNavicat.exe,选择Navicat.exe破解,再把破解的Navicat.exe放回到安装目录,完美破解!

创建快捷方式

1
2
3
cd /usr/share/applications/
sudo touch navicat.desktop
sudo vi navicat.desktop

加入以下内容

1
2
3
4
5
6
7
8
9
10
[Desktop Entry]
Encoding=UTF-8
Name=Navicat
Comment=The Smarter Way to manage dadabase
Exec=/bin/sh "/home/ybd/Data/soft/application/navicat112_mysql_en_x64/start_navicat"
Icon=/home/ybd/Data/soft/application/navicat112_mysql_en_x64/Navicat/navicat.png
Categories=Application;Database;MySQL;navicat
Version=1.0
Type=Application
Terminal=0

安装Redis

安装

终端执行:

1
2
sudo apt-get update
sudo apt-get install redis-server

启动

1
redis-server

查看是否启动成功

1
redis-cli

HelloWorld

1
2
set k1 helloword
get k1

配置相关

/etc/redis:存放redis配置文件
/var/redis/端口号:存放redis的持久化文件

通过下面的命令停止/启动/重启redis:

1
2
3
/etc/init.d/redis-server stop
/etc/init.d/redis-server start
/etc/init.d/redis-server restart

如果是通过源码安装的redis,则可以通过redis的客户端程序redis-clishutdown命令来重启redis

1
redis-cli -h 127.0.0.1 -p 6379 shutdown

如果上述方式都没有成功停止redis,则可以使用终极武器 kill -9

开启远程访问

找到redis.conf文件,一般在/etc下面:

1
2
3
➜  ~ sudo find /etc -name redis.conf
/etc/redis/redis.conf
➜ ~ sudo gedit /etc/redis/redis.conf

找到bind 127.0.0.1注释掉
注释掉本机,局域网内的所有计算机都能访问。
band localhost 只能本机访问,局域网内计算机不能访问。
bind 局域网IP 只能局域网内IP的机器访问, 本地localhost都无法访问。

博主选择将bind 127.0.0.1 改成了bind 0.0.0.0

开启发布订阅监听

还是修改redis.conf文件,找到notify-keyspace-events "",修改为notify-keyspace-events Ex或者notify-keyspace-events AKE,然后重启。

附加:基于Docker

拉取镜像:

1
docker pull redis:latest

运行实例:

1
REDIS=/home/ybd/data/docker/redis && docker run -p 6379:6379 --restart=always -v $REDIS/redis.conf:/usr/local/etc/redis/redis.conf -v $REDIS/data:/data --name redis -d redis redis-server /usr/local/etc/redis/redis.conf --appendonly yes

安装链接工具:

1
2
3
4
sudo apt-get install redis-tools

// 链接
redis-cli

安装Maven

下载

官网下载或者点击镜像获取

配置

1、下载解压到自己的指定的目录后,将命令放到/bin下:

1
sudo ln -s /自定义目录/apache-maven-3.3.9/bin/mvn /bin/mvn

2、添加环境变量
老规矩,在/etc/profile.d下创建一个maven.sh的文件:

1
2
sudo touch /etc/profile.d/maven.sh
sudo vi /etc/profile.d/maven.sh

输入以下内容:

1
2
export M2_HOME=/自定义目录/apache-maven-3.3.9
export PATH=${M2_HOME}/bin:$PATH

然后source一下:

1
source /etc/profile.d/maven.sh

查看是否配置成功:

1
mvn -v

输入内容如下:

1
2
3
4
5
6
Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-11T00:41:47+08:00)
Maven home: /home/ybd/Data/application/maven/apache-maven-3.3.9
Java version: 1.8.0_65, vendor: Oracle Corporation
Java home: /usr/local/jdk1.8.0_65/jre
Default locale: zh_CN, platform encoding: UTF-8
OS name: "linux", version: "4.4.0-67-generic", arch: "amd64", family: "unix"

淘宝镜像

1
2
3
4
5
6
7
8
<mirrors>
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
</mirrors>

MongoDB

安装

1
2
3
4
5
6
7
8
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 0C49F3730359A14518585931BC711F9BA15703C6

#下面命令针对ubuntu16.04版本,在其他ubuntu版本系统请查看MongoDB官网
echo "deb [ arch=amd64,arm64 ] http://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.4.list

sudo apt-get update

sudo apt-get install -y mongodb-org

安装完成后查看版本:

1
mongo -version

启动、重新启动和关闭mongodb命令:

1
2
3
sudo service mongod start
sudo service mongod stop
sudo service mongod restart

查看是否启动成功:

1
sudo cat /var/log/mongodb/mongod.log

mongod.log 日志中若出现如下信息,说明启动成功:

1
[initandlisten] waiting for connections on port 27017

MongoDB 卸载

删除 mongodb 包

1
sudo apt-get purge mongodb-org*

删除 MongoDB 数据库和日志文件

1
2
sudo rm -r /var/log/mongodb
sudo rm -r /var/lib/mongodb

MongoDB 使用

shell命令模式
输入mongo进入shell命令模式,默认连接的数据库是test数据库,命令如下:

1
➜  ~ mongo

常用操作命令:

show dbs:显示数据库列表
show collections:显示当前数据库中的集合(类似关系数据库中的表table)
show users:显示所有用户
use yourDB:切换当前数据库至yourDB
db.help() :显示数据库操作命令
db.yourCollection.help() :显示集合操作命令,yourCollection是集合名

官方文档:https://docs.mongodb.com/master/tutorial/install-mongodb-on-ubuntu/

GUI客户端

Robomongo

RabbitMQ

选择Docker安装。。。不折腾了。。

1
2
docker pull rabbitmq:3-management
docker run -d --name rabbitmq -p 5673:5672 -p 15673:15672 --restart=always rabbitmq:3-management

(注意版本,是management)

浏览器打开localhost:15673,默认帐号密码都是guest

集群:https://www.jianshu.com/p/624871c646b9

Kafka&Zookeeper集群

docker-compose.yml:

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
version: '3'
services:
kafka1:
image: wurstmeister/kafka:1.0.0
depends_on:
- zoo1
- zoo2
- zoo3
ports:
- "9092:9092"
environment:
KAFKA_LOG_DIRS: /kafka
KAFKA_BROKER_ID: 1
KAFKA_CREATE_TOPICS: test:6:1
KAFKA_ADVERTISED_HOST_NAME: 192.168.6.113
KAFKA_ADVERTISED_PORT: 9092
KAFKA_ZOOKEEPER_CONNECT: zoo1:2181,zoo2:2181,zoo3:2181

kafka2:
image: wurstmeister/kafka:1.0.0
depends_on:
- zoo1
- zoo2
- zoo3
ports:
- "9093:9092"
environment:
KAFKA_LOG_DIRS: /kafka
KAFKA_BROKER_ID: 2
KAFKA_ADVERTISED_HOST_NAME: 192.168.6.113
KAFKA_ADVERTISED_PORT: 9093
KAFKA_ZOOKEEPER_CONNECT: zoo1:2181,zoo2:2181,zoo3:2181

kafka3:
image: wurstmeister/kafka:1.0.0
depends_on:
- zoo1
- zoo2
- zoo3
ports:
- "9094:9092"
environment:
KAFKA_LOG_DIRS: /kafka
KAFKA_BROKER_ID: 3
KAFKA_ADVERTISED_HOST_NAME: 192.168.6.113
KAFKA_ADVERTISED_PORT: 9094
KAFKA_ZOOKEEPER_CONNECT: zoo1:2181,zoo2:2181,zoo3:2181

zoo1:
image: zookeeper:latest
environment:
ZOO_MY_ID: 1
SERVERS: zoo1,zoo2,zoo3
ports:
- "2181:2181"
- "2888"
- "3888"

zoo2:
image: zookeeper:latest
environment:
ZOO_MY_ID: 2
SERVERS: zoo1,zoo2,zoo3
ports:
- "2182:2181"
- "2888"
- "3888"

zoo3:
image: zookeeper:latest
environment:
ZOO_MY_ID: 3
SERVERS: zoo1,zoo2,zoo3
ports:
- "2183:2181"
- "2888"
- "3888"

启动:

1
docker-compose up -d

测试:

1
2
3
4
5
6
7
8
9
10
11
#创建主题
docker exec -it ${CONTAINER_ID} /opt/kafka/bin/kafka-topics.sh --create --zookeeper zoo1:2181 --replication-factor 1 --partitions 1 --topic test

#查看topic列表
docker exec -it ${CONTAINER_ID} /opt/kafka/bin/kafka-topics.sh --list --zookeeper zoo1:2181

#生产者
docker exec -it ${CONTAINER_ID} /opt/kafka/bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test

#消费者
docker exec -it ${CONTAINER_ID} /opt/kafka/bin/kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic test --from-beginning

搭建ngrok配置

ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。ngrok 可捕获和分析所有通道上的流量,便于后期分析和重放。可以被使用来进行微信借口的本地调试。在ngrok被墙之后,我们需要通过ngrok开源的源码自行搭建ngrok服务。

参考地址:Ubuntu下配置安装ngrok
搞了一上午,服务运行起来了,客户端也运行起来了,浏览器就是访问不到!!
不知道是不是因为个人电脑没有域名所以才访问不到,日后再深究。
无奈,还好互联网开源精神无处不在,某大神搭建的ngrok:
http://www.qydev.com/
客户端和教程都在里面哦。

Update:Ngrok已搭建成功~ ,记录于self-hosted-build-ngrok-server

其他tunnel的代理服务器
natapp.cn
www.ngrok.cc


  1. 1.IDEA 全称IntelliJ IDEA,是java语言开发的集成环境,IntelliJ在业界被公认为最好的java开发工具之一,尤其在智能代码助手、代码自动提示、重构、J2EE支持、Ant、JUnit、CVS整合、代码审查、 创新的GUI设计等方面的功能可以说是超常的。IDEA是JetBrains公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主
---------------- The End ----------------
ookamiAntD wechat
欢迎您扫一扫上面的微信公众号,订阅我的博客!
谢谢大爷~

Author:ookamiAntD Yang
Link:http://yangbingdong.com/2017/ubuntu-dev-environment-to-build/
Contact:yangbingdong1994@gmail.com
本文基于 知识共享署名-相同方式共享 4.0 国际许可协议发布
转载请注明出处,谢谢!

分享到: