阿里云 Centos7 部署Java web [jar/war/nginx+域名服务]

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: (一)第一部分:最基本的jar包运行(无需配置tomcat) [http://60.205.183.114:8081/] 1、配置阿里云(Esc学生服务器、镜像Centos7.7),并远程连接进入终端。

(一)第一部分:最基本的jar包运行(无需配置tomcat)

[http://60.205.183.114:8081/]

a)安装jdk。
b)寻找jdk路径配置环境变量。
c)简单的Java hello world测试确保安装成功。

a)安装mysql、mariadb server。
b)systemctl 开启服务。
c) 打开端口。(阿里云要在控制台打开)
d) 更改mysql 的root密码,对应于项目配置文件中的密码。

a)传输spring maven 的快照版本用于测试。
b)传输数据库sql文件。

  • 5、导入数据库

a)创建sql文件对应的数据库。
b)利用文件重定向运行sql文件。
c)检查数据库是否导入成功

  • 6、运行jar文件,控制台获取公网IP,本机输入IP:8081测试。
  • 7、设置后台运行(已设置:http://60.205.183.114:8081/)

a)contrl+c中止。
b)然后通过nohup 和 & 来后台运行。
c)ps通过pid来停止后台运行进程。

运行结果
整体过程:

[root@iZ2ze4r3b4xcztbcsey08cZ ~]# history
    1   MAKRER=SHOW_LOCALE;printf $MAKRER""; locale; MAKRER=SHOW_LOCALE;printf $MAKRER"";
    2  yum install -y mysql
    3  yum install -y mariadb-server mariadb
    4  systemctl start mariadb
    5  systemctl enable mariadb
    6  yum install -y mysql-devel
    7  firewall-cmd --zone=public --add-port=3306/tcp --permanent
    8   CHECK_TYPE=SHELL; echo "INFO=${CHECK_TYPE} PID=$$ PPID=$PPID TTY=$(tty) SHELL=$0 HOME=$HOME PWD=$PWD| CHECK_SHELL_END"
    9  ls
   10  ifconfig
   11  ls
   12  yum list
   13  java -version
   14  ls
   15  yum search java-1.8
   16  yum -y install java-1.8.0-openjdk-devel.x86_64
   17  java -version
   18  cd /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.252.b09-2.el7_8.x86_64/
   19  pwd
   20  vim /etc/profile
   21  . /etc/profile
   22  vim Demo.java
   23  javac  Demo.java
   24  java Demo
   25  su
   26   MAKRER=SHOW_LOCALE;printf $MAKRER""; locale; MAKRER=SHOW_LOCALE;printf $MAKRER"";
   27   CHECK_TYPE=SHELL; echo "INFO=${CHECK_TYPE} PID=$$ PPID=$PPID TTY=$(tty) SHELL=$0 HOME=$HOME PWD=$PWD| CHECK_SHELL_END"
   28  mysql -u root
   29  ls
   30  pwd
   31  ifconfig
   32  ls
   33  mysql
   34  mysql -u root jpetstore < jpetstore.sql
   35  mariadb
   36  mysql
   37  java -jar mypetstore-0.0.3-SNAPSHOT.jar
   38  nohup java -jar mypetstore-0.0.3-SNAPSHOT.jar &
   39  ps
   40  history
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# 

控制台开端口

利用scp传文件
image

运行mysql 文件

[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 3
Server version: 5.5.65-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> create database jpetstore;
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> quit
Bye
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mysql -u root jpetstore < jpetstore.sql 
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mariadb
-bash: mariadb: command not found
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 5
Server version: 5.5.65-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| jpetstore          |
| mysql              |
| performance_schema |
| test               |
+--------------------+
5 rows in set (0.00 sec)

MariaDB [(none)]> use jpetstore;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
MariaDB [jpetstore]> show tables;
+---------------------+
| Tables_in_jpetstore |
+---------------------+
| account             |
| addlog              |
| bannerdata          |
| browselog           |
| cart                |
| cartitem            |
| category            |
| inventory           |
| item                |
| lineitem            |
| orders              |
| orderstatus         |
| product             |
| profile             |
| sequence            |
| signon              |
| supplier            |
+---------------------+
17 rows in set (0.00 sec)

访问http://60.205.183.114:8081/

image

(二)第二部分:利用Tomcat容器对war包进行处理(需要Tomcat)

[http://60.205.183.114:8080/myJPetStore_war/index.jsp]

a)本地下载tomcat,然后利用scp文件传输
b)设置访问权限
c)设置服务配置
d)输入IP:8080测试是否已经开启服务

  • 2、数据库/端口配置

a)数据库root 密码 和服务器对应
b)端口配置,在上面已经开启了8080端口

  • 3、利用scp传输war包,放到webapp里边(直接会解析出文件)
  • 4、重启tomcat服务

a)bin下的shutdown.sh
b)bin下的startup.sh

  • 5、本机测试访问

a)注意要添加访问的资源的路径/myJPetStore_war/index.jsp,然后tomcat容器会自动到webapp下去寻找
b) 已设置tomcat容器:http://60.205.183.114:8080/myJPetStore_war/index.jsp

运行结果
整体过程

   52  ls
   53  sudo mkdir /opt/tomcat
   54  sudo tar xvf apache-tomcat-8*tar.gz -C /opt/tomcat --strip-components=1
   55  cd /opt/tomcat
   56  sudo chgrp -R tomcat /opt/tomcat
   57  sudo chmod -R g+r conf
   58  sudo chmod g+x conf
   59  sudo chown -R tomcat webapps/ work/ temp/ logs/
   60  sudo vi /etc/systemd/system/tomcat.service
   61  sudo systemctl daemon-reload
   62  sudo systemctl start tomcat
   63  sudo systemctl status tomcat
   64  sudo systemctl enable tomcat
   65  ls
   66  cd webapps/
   67  pwd
   68  ls
   69  sudo systemctl restart tomcat
   70  cd ../bin/
   71  ls
   72  sh shutdown.sh 
   73  sh startup.sh 
   74  history
[root@iZ2ze4r3b4xcztbcsey08cZ bin]# 

利用systemctl查看tomcat的状态
image

验证是否开启tomcat服务
image

将war包直接传入webapp中
image

然后webapp会自动解析war包(即myJPetStore_war)

[root@iZ2ze4r3b4xcztbcsey08cZ webapps]# pwd
/opt/tomcat/webapps
[root@iZ2ze4r3b4xcztbcsey08cZ webapps]# ls
docs  examples  host-manager  manager  myJPetStore_war  myJPetStore_war.war  ROOT

访问http://60.205.183.114:8080/myJPetStore_war/index.jsp

image

(三)第三部分:指定域名进行访问

[http://crf.codes/]

  • 1、配置virmach vps,达到可以通过IP进行访问

a)过程同第一步,最后设置为后台运行。
b) 已配置:http://198.12.120.212:8081/

a)ping 域名(ping crf.codes)查看是否绑定成功。

  • 4、修改nginx 配置文件

a)Web server 设定域名
b)Location 配置index界面
c)开放Linux系统防火墙
d)访问crf.code http://crf.codes/

运行结果
域名提供商(name)配置dns

image

验证dns是否配置成功
ping crf.codes,可以看到
image

修改nginx配置文件

server {
    listen       80;
    server_name   crf.codes;

    #charset koi8-r;
    access_log  /var/log/nginx/host.access.log  main;

    location / {
        # root   /usr/share/nginx/html;
        index  index.html index.htm;
        proxy_pass http://127.0.0.1:8081/;
        # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

访问crf.codes

image

目录
相关文章
|
2月前
|
域名解析 网络协议
非阿里云注册域名如何在云解析DNS设置解析?
非阿里云注册域名如何在云解析DNS设置解析?
|
2月前
|
存储 安全 数据库
阿里云最新域名注册和续费、企业邮箱、云虚拟主机收费标准与价格参考
域名注册和续费以及企业邮箱和云虚拟主机是很多用户上云第一步需要购买的产品,从2024年9月1日开始,全球域名又迎来了一波价格上调,目前阿里云的.com英文域名的注册价格由原来的78元涨价到了83元,续费价格也涨到了90元,不过企业新用户注册有1元购等活动。企业邮箱目前活动价540.00元/1年起,云虚拟主机独享基础增强版月付49元/1个月起,年付588元/1年起。本文为大家整理汇总了截止目前,阿里云域名注册和续费及转入收费标准、企业邮箱收费标准与活动价格、云虚拟主机最新收费标准,以供参考。
|
2月前
|
弹性计算 网络协议 安全
如何使用阿里云虚拟主机和域名设置网站?
如何使用阿里云虚拟主机和域名设置网站?
|
2月前
|
应用服务中间件 Linux nginx
CentOS7安装Nginx
CentOS7安装Nginx
|
2月前
|
网络协议 安全 网络安全
阿里云国际修改域名绑定的DDoS高防服务器
阿里云国际修改域名绑定的DDoS高防服务器
|
2月前
|
监控 安全 BI
阿里云国际跨账号迁移CDN域名操作步骤
阿里云国际跨账号迁移CDN域名操作步骤
|
2月前
|
域名解析 网络协议
阿里云如何找回域名,进行添加或删除?
阿里云如何找回域名,进行添加或删除?
|
2月前
|
网络安全
阿里云国际版如何为SSL证书更换域名?
阿里云国际版如何为SSL证书更换域名?
|
2月前
|
监控 数据安全/隐私保护 CDN
防止域名被攻击或盗刷产生突发高带宽,阿里云国际如何设置带宽上限值?
防止域名被攻击或盗刷产生突发高带宽,阿里云国际如何设置带宽上限值?
|
2月前
|
弹性计算 网络协议 数据库
在阿里云国际站上解析域名到服务器详细教程
在阿里云国际站上解析域名到服务器详细教程