阿里云 Debian 9.2 安装 Java Web 环境
CentOS 源内包太旧,和本地开发环境不兼容的地方太多
系统配置
更新数据库与软件包
# apt-get update && apt-get -y upgrade
提示是否保留本地已修改文件时选择 install the package maintainer's version安装 vim 与 unzip
# apt-get -y install vim unzip
修改 SSH 端口,
# vim /etc/ssh/sshd_config
,查找 22,该行应该是注释掉的,反注释掉后修改为Port ${PORN_NUM}
,重启 ssh# systemctl restart sshd
添加一个新用户,此处用户名为 seliote,
# useradd -m -s /bin/bash seliote
,添加 sudo 权限# visudo
,root ALL=(ALL) ALL
下行添加seliote ALL=(ALL) ALL
,更新用户密码# passwd seliote
,添加 SSH 登录密钥并更改所属用户# cp -R ~/.ssh /home/seliote/ && chown -R seliote:seliote /home/seliote/.ssh
,切换过去修改一下 .bashrc,# su - seliote
,$ vim ~/.bashrc
,末尾添加以下内容
alias ll='ls -lh --color=auto'
alias grep='grep --color=auto'
alias mariadb_console='mysql -u root -p'
export JAVA_WEB_PATH="/var/lib/tomcat8/webapps"
PMT_ORANGE="\[$(tput setaf 3)\]"
PMT_RESET="\[$(tput sgr0)\]"
export PS1="${PMT_ORANGE}\u \A \w >>>${PMT_RESET} "
退出普通用户 $ exit
,准备开始安装 Web 环境
安装 JRE, Tomcat, MariaDB
搜索 JRE 包名,
# apt-cache search java | grep jre
,这里使用openjdk-8-jre
,安装 JRE# apt-get -y install openjdk-8-jre
搜索 Tomcat 包名
apt-cache search tomcat
,这里用tomcat8
,安装 Tomcat# apt-get -y install tomcat8
,# dpkg -L tomcat8
查询 tomcat8 安装路径搜索 MariaDB 包名
apt-cache search mariadb
,这里用mariadb-server
,安装 MariaDB# apt-get -y install mariadb-server
,需要更新版本的可以参考 MariaDB 官方网站Debian 上安装完成后 Tomcat 与 MariaDB 是默认自启的
配置 Tomcat,
# vim /etc/tomcat8/web.xml
,搜索org.apache.jasper.servlet.JspServlet
,下一行添加
<init-param>
<param-name>compilerSourceVM</param-name>
<param-value>1.8</param-value>
</init-param>
<init-param>
<param-name>compilerTargetVM</param-name>
<param-value>1.8</param-value>
</init-param>
以开启 Java 8 的支持
- 配置 MariaDB,
# mysql_secure_installation
,按照向导进行配置即可,但是安装完成后默认是可以无需密码登录的,更改一下# mysql
进入 MariaDB 的回显,换库> USE mysql;
,替换默认的 unix_socket 插件(或者直接置空''也可以)> UPDATE `user` SET `plugin` = 'mysql_native_password' WHERE `User` = 'root';
,刷新权限> FLUSH PRIVILEGES;
,退出> exit
域名解析与 HTTPS
添加域名解析,阿里云控制台域名列表,选择解析,添加记录,记录类型为
A
,主机记录为@
以解析主域名,解析线路默认即可,记录值为 ECS 的 IP 地址,TTL 10 分钟即可,按需添加其他解析记录申请 SSL 证书,点击全部产品,安全,SSL 证书,购买证书,Symantec,免费型 DV SSL,选择一个域名,购买,然后返回证书控制台,点击 SSL 证书的申请,证书绑定域名输入一级域名即可,域名验证方式为自动 DNS 验证,CSR 生成方式为系统生成,下一步,验证,提交审核,等待验证完成
安装 SSL 证书,签发完成后下载 SSL 证书,下载 Tomcat 的版本,解压后得到 pfx 与 txt 文件各一个,上传 pfx 文件到服务器,比如上传后 pfx 文件为
~/seliote.com.pfx
,切换到 Tomcat 配置目录# cd /etc/tomcat8/
,创建一个存储证书的文件夹# mkdir cert
,证书复制过去# cp ~/seliote.com.pfx cert/
,编辑 Tomcat 的配置# vim server.xml
,添加一个端口为 8443 的Connector
节点,这里使用的协议是Http11NioProtocol
,其他两种协议Http11Protocol
与Http11AprProtocol
前者性能太差,后者较难配置,sslProtocol
值使用 TLSv1.2,同时支持 SSLv3, TLSv1, TLSv1.1 和 TLSv1.2
<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="150" SSLEnabled="true" scheme="https" secure="true" clientAuth="false" sslProtocol="TLSv1.2"
keystoreFile="/etc/tomcat8/cert/seliote.com.pfx" keystorePass="${UNZIPED_TXT_FILE_CONTENT}" />
- 开启 HTTP 自动跳转 HTTPS,编辑配置文件
# vim web.xml
,根节点末尾之前添加
<security-constraint>
<web-resource-collection>
<web-resource-name>HttpsOnly</web-resource-name>
<url-pattern>/*</url-pattern>
</web-resource-collection>
<user-data-constraint>
<transport-guarantee>CONFIDENTIAL</transport-guarantee>
</user-data-constraint>
</security-constraint>
- 重启 Tomcat 即可
# systemctl restart tomcat8
后续 Bug 排查
系统重启发现 Tomcat 会发生阻塞,systemd 的状态是 activity,浏览器不报错也无法访问,主机
# curl -v http://127.0.0.1:8080
都是阻塞状态,但是几分钟后就又恢复了,查看日志发现了这行org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [393,380] milliseconds
,看到随机数生成了六分多钟,阻塞是应该的了,尝试安装一个随机数生成器,# apt-cache search rng-tools
,查到了两个 rng-tools 和 rng-tools5,装 rng-tools 结果报错,查 Debian Wiki 发现对硬件有限制,在 Wiki 里看到 rng-tools5 支持新硬件,尝试安装,# apt-get install rng-tools5
,成功,重启 ECS,这次直接就可以访问了上面有禁用 root 远程登录,需要的话可以打开
> UPDATE user SET Host = '%' WHERE User = 'root';
> FLUSH PRIVILEGES;
需要关闭的时候再 设置为localhost
即可
阿里云 Debian 9.2 安装 Java Web 环境的更多相关文章
- 阿里云windows 2012服务器部署java web程序教程
一:环境搭建 1.首先需要购买一个阿里云ECS服务器,购买时可以选择处理器核数以及内存大小(可以购买偏低配置,因为升级 方便) 2.购买后会自动创建一个实例,可以使用该实例中显示的公网地址在 ...
- Linux安装JAVA web环境
一:安装jdk 1.下载 在oracle下载东西的时候因为oracle的一些验证机制,所以需要在链接前面添加一些参数 wget --no-check-certificate --no-cookie ...
- 阿里云服务器ubuntu安装java运行环境
服务器 阿里云服务器ubuntu安装java运行环境 转:http://www.codingyun.com/article/45.html 今天来给大家介绍一下在阿里云ubuntu服务器下安装java ...
- 阿里云搭建JAVA WEB环境(SQL Server + TomCat + 配置域名)
假期刚刚搭完,先写个提纲,今晚写完: 1.申请一个月的免费的云服务器ECS; 2.在云服务器上安装Java开发环境+Sql Server+Tomcat; 3.购买域名并认证,绑定服务器共有IP地址; ...
- 阿里云服务器Linux CentOS安装配置(九)shell编译、打包、部署
阿里云服务器Linux CentOS安装配置(九)shell编译.打包.部署 1.查询当前目录以及子目录下所有的java文件,并显示查询结果 find . -name *.java -type f - ...
- 阿里云服务器Linux CentOS安装配置(一)购买阿里云服务器
阿里云服务器Linux CentOS安装配置(一)购买阿里云服务器 我在阿里云购买的服务器配置 CPU:1核 内存:2G 系统盘:40G 公共镜像:CentOS 6.5 64位 公网带宽:1Mbps ...
- 阿里云CentOS7系列一 -- 安装JDK7的方法.
最近因为数据采集以及生产环境冲突.导入windows Server 2008系统经常死机.经讨论决定把采集服务程序和生产服务进行分开.采集程序通过windows Server2008运行.而生产程序通 ...
- 阿里云服务器Linux CentOS安装配置(六)resin多端口配置、安装、部署
阿里云服务器Linux CentOS安装配置(六)resin多端口配置.安装.部署 1.下载resin包 http://125.39.66.162/files/2183000003E08525/cau ...
- 阿里云服务器Linux CentOS安装配置(四)yum安装tomcat
阿里云服务器Linux CentOS安装配置(四)yum安装tomcat 1.yum -y install tomcat 执行命令后,会帮你把jdk也安装好 2.tomcat安装目录:/var/li ...
随机推荐
- js 对象数组删除和查找的方法
deleteItem: function (array,item) { const index = this.array.findIndex(text => text.name === item ...
- springMVC框架下返回json格式的对象,list,map
原文地址:http://liuzidong.iteye.com/blog/1069343 注意这个例子要使用jQuery,但是jquery文件属于静态的资源文件,所以要在springMVC中设置静态资 ...
- UVa 10003 - Cutting Sticks(区间DP)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- BZOJ2337:[HNOI2011]XOR和路径(高斯消元)
Description 给定一个无向连通图,其节点编号为 1 到 N,其边的权值为非负整数.试求出一条从 1 号节点到 N 号节点的路径,使得该路径上经过的边的权值的“XOR 和”最大.该路径可以重复 ...
- 【[HNOI2005]狡猾的商人】
加权并查集 由于给出信息的是一些一个区间的和为多少,我们显然并不好处理出每一个点应该为多少,这我们根本做不到 但是我们想一下,如果要求一个区间\([l,r]\)的和,那么我们是不是可以利用前缀和\(p ...
- PAT——1010. 一元多项式求导
设计函数求一元多项式的导数.(注:xn(n为整数)的一阶导数为n*xn-1.) 输入格式:以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. 输出格式:以与 ...
- 在windows service中启动类型“Automatic” 和 “Automatic (Delayed start)” 有何不同?
问题: When installing Windows services there are two options for automatically starting a Windows serv ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 036-037
这几天比较忙,所以随便做做水题了,得赶紧把英剧搞完啊啊啊啊啊啊 ------------------------------------------------L1-036-------------- ...
- python初学者日记01(字符串操作方法)
时间:2018/12/16 作者:永远的码农(博客园) 环境: win10,pycharm2018,python3.7.1 1.1 基础操作(交互输入输出) input = input(" ...
- 05JavaScript语句
1.JavaScript 语句 JavaScript 语句是发给浏览器的命令. 这些命令的作用是告诉浏览器要做的事情. 2.分号 ; 分号用于分隔 JavaScript 语句. 通常我们在每条可执行的 ...