前言:

之前我们提及了怎样使用Maven来创建、管理和打包项目,也简单过了一遍Linux中搭建Java开发环境的步骤,如今我们就開始将我们之前开发的项目demo公布到Linux环境下。并让它正常执行起来。

公布思路:

  • 使用Maven将项目打包为.jar
  • 将项目的.jar和项目全部依赖的jar包都拷贝到Linux下
  • 创建项目启动脚本来启动项目

准备工作:

  • 查询Linux系统机器的Ip地址:方法非常easy,在Linux中打开终端输入ifconfig就可以查到Ip地址为192.168.35.130

  • 改动Eclipse中client和server的连接Ip地址改为此地址:
    private static final String IP = "192.168.35.130";
private static final int PORT = 8088;

Maven打包项目:

在之前的篇幅中我们已经解说了Maven的相关常识,这里我们一開始没有使用Maven来创建项目,而是使用Eclipse创建了一个Java Application,这里要使用Maven来管理已创建好的Eclipse工程。过程例如以下:

  • 安装EclipseMaven插件:

    在Eclipse中点击Help->Eclipse Marketplace,搜索maven在搜索结果列表中找到Maven Integration for Eclipse插件。假如未安装则点击Install进行安装,已安装但非最新版本号能够点击Update,已经安装且为最新版本号显示Installed:

  • 普通Eclipse项目Maven适配:

    在Eclipse选中项目根文件夹,右键Configure->Convert To Maven Project:



    在弹窗中输入Group Id(包名。通常是域名反写)、Artifact Id(工程名称)和Version:



    操作完毕之后。在项目下面多出了一个pom.xml文件

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.tw.login</groupId>
    <artifactId>TWLogin</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <build>
    <sourceDirectory>src</sourceDirectory>
    <resources>
    <resource>
    <directory>src</directory>
    <excludes>
    <exclude>**/*.java</exclude>
    </excludes>
    </resource>
    </resources>
    <plugins>
    <plugin>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.5.1</version>
    <configuration>
    <source>1.8</source>
    <target>1.8</target>
    </configuration>
    </plugin>
    </plugins>
    </build>
    </project>
  • 项目依赖于其它项目:

    能够打开pom.xmlDependencies页签,通过Add进行加入,加入时输入能够通过输入GroupId和ArtifactId进行搜索:

    比如:我们项目中使用了Netty来搭建网络层开发。所以要将其jar包加入到Dependencies中:



    须要将本地/lib文件夹中的.jar一一加入到Dependencies:



    或者是选中pom.xml右键Maven->Add Dependency也能够进入到加入依赖的窗体。也能够在pom.xml中直接加入<dependencies>...</dependencies>,加入一下内容:

    <dependencies>
    <dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    <version>1.2</version>
    </dependency>
    <dependency>
    <groupId>io.netty</groupId>
    <artifactId>netty-all</artifactId>
    <version>4.0.42.Final</version>
    </dependency>
    <dependency>
    <groupId>com.google.protobuf</groupId>
    <artifactId>protobuf-java</artifactId>
    <version>2.5.0</version>
    </dependency>
    <dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.1.0</version>
    </dependency>
    <dependency>
    <groupId>commons-pool</groupId>
    <artifactId>commons-pool</artifactId>
    <version>1.6</version>
    </dependency>
    </dependencies>
  • 项目打包:

    通常通过命令行窗体和Maven指令来进行打包。但这是我们能够直接在Eclipse中进行打包简化打包流程,Jave Application工程会被打包成.jar包,而Jave Web工程则打包成.war包,这里我们要将Java Application打包成一个可执行程序的jar包。须要提前考虑三个步骤:

    • 配置文件须要打进jar包;
    • 须要制定程序的main入口类。
    • 全部依赖的第三方库也要打进jar包。

    满足以上三个条件的话,我们就能使用java -jar xxx.jar来执行我们的程序了,为了满足这个目的,我们通常须要借助一些辅助于Maven的打包插件。常见的有maven-assembly-pluginmaven-shade-plugin,可是使用maven-assembly-plugin的话会把全部须要打到包里的文件全部打成一个.jar包,并且假如第三方配置文件于本地配置文件存在重名时,会出现直接覆盖的bug,所以这里我们还是选用maven-shade-plugin插件来打包。

    • 改动pom.xml。首先引入maven-shade-plugin,须要在<build><plugins><plugin>...</plugin></plugins></build>中加入:

      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-shade-plugin</artifactId>
      <version>1.4</version>

    在同等级位置加入入口类和并制定打包插件(当中<goal>shade</goal>就指定了打包插件使用maven-shade-plugin):

    <executions>
    <execution>
    <phase>package</phase>
    <goals>
    <goal>shade</goal>
    </goals>
    <configuration>
    <transformers>
    <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
    <!-- 定义入口类 -->
    <mainClass>com.tw.login.LoginSocketServer</mainClass>
    </transformer>
    </transformers>
    </configuration>
    </execution>
    </executions>
    • 方法一:在Eclipse中选中项目的pom.xml文件,右键Run As->Maven Clean,假如清理成功,target文件夹中的编译生成文件都被清除掉:

      [INFO] Scanning for projects...
      [INFO]
      [INFO] ------------------------------------------------------------------------
      [INFO] Building TWLogin 0.0.1-SNAPSHOT
      [INFO] ------------------------------------------------------------------------
      [INFO]
      [INFO] --- maven-clean-plugin:2.5:clean (default-clean) @ TWLogin ---
      [INFO] Deleting E:\java web\workplace\TWLogin\target
      [INFO] ------------------------------------------------------------------------
      [INFO] BUILD SUCCESS
      [INFO] ------------------------------------------------------------------------
      [INFO] Total time: 0.293 s
      [INFO] Finished at: 2017-03-24T13:09:58+08:00
      [INFO] Final Memory: 7M/153M
      [INFO] ------------------------------------------------------------------------

    然后执行打包指令:选中项目的pom.xml文件。右键Run As->Maven Build

    假如报错:

    [ERROR] No goals have been specified for this build. You must specify a valid lifecycle phase or a goal in the format <plugin-prefix>:<goal> or <plugin-group-id>:<plugin-artifact-id>[:<plugin-version>]:<goal>. Available lifecycle phases are: validate, initialize, generate-sources, process-sources, generate-resources, process-resources, compile, process-classes, generate-test-sources, process-test-sources, generate-test-resources, process-test-resources, test-compile, process-test-classes, test, prepare-package, package, pre-integration-test, integration-test, post-integration-test, verify, install, deploy, pre-clean, clean, post-clean, pre-site, site, post-site, site-deploy. -> [Help 1]
    [ERROR]
    [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
    [ERROR] Re-run Maven using the -X switch to enable full debug logging.
    [ERROR]
    [ERROR] For more information about the errors and possible solutions, please read the following articles:
    [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/NoGoalSpecifiedException

    pom.xml文件<build>标签里面加上<defaultGoal>compile</defaultGoal>就可以,假如又出现例如以下错误:

    [ERROR] COMPILATION ERROR :
    [INFO] -------------------------------------------------------------
    [ERROR] No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
    [INFO] 1 error
    [INFO] -------------------------------------------------------------
    [INFO] ------------------------------------------------------------------------
    [INFO] BUILD FAILURE
    [INFO] ------------------------------------------------------------------------
    [INFO] Total time: 0.594 s
    [INFO] Finished at: 2017-03-24T14:06:13+08:00
    [INFO] Final Memory: 10M/153M
    [INFO] ------------------------------------------------------------------------
    [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project TWLogin: Compilation failure
    [ERROR] No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
    [ERROR] -> [Help 1]

    解决方式是:在Eclipse选中项目,右键->Properties->Project Facets,勾选Apache Tomcat。由于Eclipse中Maven打包依赖Tomcat服务:

    正确的输出结果例如以下:

    [INFO] Scanning for projects...
    [INFO]
    [INFO] ------------------------------------------------------------------------
    [INFO] Building TWLogin 0.0.1-SNAPSHOT
    [INFO] ------------------------------------------------------------------------
    [INFO]
    [INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ TWLogin ---
    [WARNING] Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
    [INFO] Copying 1 resource
    [INFO]
    [INFO] --- maven-compiler-plugin:3.5.1:compile (default-compile) @ TWLogin ---
    [INFO] Nothing to compile - all classes are up to date
    [INFO] ------------------------------------------------------------------------
    [INFO] BUILD SUCCESS
    [INFO] ------------------------------------------------------------------------
    [INFO] Total time: 1.801 s
    [INFO] Finished at: 2017-03-22T13:07:50+08:00
    [INFO] Final Memory: 10M/217M
    [INFO] ------------------------------------------------------------------------

    假如出现编码的警告,要解决这个警告,仅仅需在pom.xml<project>标签内加入下面内容指定编码方式:

    <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>
    • 方法二:能够打开命令行窗体,定位到当前项目的文件夹下,使用mvn clean package进行打包,相关依赖信息和打包方式在pom.xml中配置:

  • 打包成功后,在项目的target文件夹下会生成相应Version版本号的.jar包。比如这里我的输出包为:TWLogin-0.0.1-SNAPSHOT.jar,这就是我们要用来放到Linuxserver中执行的源代码包:

Linux下安装Maven:

  • Maven官网下载最新的Maven安装包。这里我下载的是:apache-maven-3.3.9-bin.tar.gz
  • 通过终端解压安装包到/usr/local文件夹下:

    sudo tar -xzf /mnt/Windows/apache-maven-3.3.9-bin.tar.gz -C /usr/local/jvm
  • 改动用户变量配置文件~/.bashrc和系统环境配置文件/etc/profile,都是在文件最后插入Maven的配置信息:


    #Set maven environment MAVEN_HOME=/usr/local/jvm/apache-maven-3.3.9
    export MAVEN_HOME
    export PATH=${PATH}:${MAVEN_HOME}/bin
  • 使用source .bashrcsource /etc/profile使改动配置文件内容马上生效,使用mvn -v測试安装是否成功,假设成功。则显示当前安装的Maven的版本号信息:

    linsh@ubuntu:~$ mvn -v
    Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-10T08:41:47-08:00)
    Maven home: /usr/local/jvm/apache-maven-3.3.9
    Java version: 1.8.0_121, vendor: Oracle Corporation
    Java home: /usr/local/jvm/jdk1.8.0_121/jre
    Default locale: zh_CN, platform encoding: UTF-8
    OS name: "linux", version: "4.2.0-27-generic", arch: "amd64", family: "unix"
    linsh@ubuntu:~$

在Linux中执行项目:

  • 我们将之前打包得到的TWLogin-0.0.1-SNAPSHOT.jar拷贝到Linux中,新建一个文件夹作为项目总文件夹application,然后再为每一个项目创建一个子文件夹。这里我们以我们的项目名称来创建子文件夹,将项目文件拷贝到此文件夹下:

    sudo mkdir /application
    sudo mkdir /application/TWLogin
    sudo cp -r /mnt/Windows/TWLogin /application/TWLogin
  • 測试执行项目:

    直接进到项目文件夹/application/TWLogin中。使用执行指令java -jar TWLogin-0.0.1-SNAPSHOT.jar执行程序,然后再在Eclipse中启动client代码。尝试连接server并发送数据。假如执行正常,情况例如以下:

    linsh@ubuntu:/application/TWLogin$ java -jar TWLogin-0.0.1-SNAPSHOT.jar
    三月 21, 2017 10:07:42 上午 com.tw.login.LoginSocketServer main
    信息: 開始启动Socketserver...
    三月 21, 2017 10:07:42 上午 com.tw.login.LoginSocketServer run
    信息: Socketserver已启动完毕
    三月 21, 2017 10:07:54 上午 com.tw.login.LoginSocketServer channelRead
    信息: 数据内容:UserName=linshuhe,Password=123456

    注:

    假如你也跟我一样出现这个错误:TWLogin-0.0.1-SNAPSHOT.jar中没有主清单属性,那么恭喜你跟我一样犯了个低级错误。忘了在使用maven打包项目之前,在pom.xml中加入项目的入口函数main的相关路径信息,解决方式就是在pom.xml的中加入下面内容:

    <transformers>
    <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
    <mainClass>com.tw.login.server.LoginSocketServer</mainClass>
    </transformer>
    </transformers>

    此处com.tw.login.server.LoginSocketServer脚本中的main函数即使本应用入口函数。

  • 创建启动脚本:

    我们为了避免每次执行项目都敲一遍启动项目所需的指令,一般会将指令封装成一个启动脚本。在Windows系统下我们通常使用.bat的批处理脚本来进行批处理。把非常多命令放在此文件里。当然也能作为一些应用程序的启动脚本。而在Linux系统中,使用shell脚本来实现同等的效果,Shell脚本是Linux的一种文本文件。这里我们就来编辑一下启动脚本start.sh的内容:


    #!bin/sh echo 假设不能正常执行,请安装JDK 1.8版
    java -jar TWLogin-0.0.1-SNAPSHOT.jar
  • 执行启动脚本:

    启动脚本通常放到与可执行.jar文件同级的文件夹下,在终端中定位到脚本所在的文件夹。执行:

    sh start.sh

《从零開始搭建游戏server》项目公布到Linux环境的更多相关文章

  1. # 从零開始搭建Hadoop2.7.1的分布式集群

    Hadoop 2.7.1 (2015-7-6更新),Hadoop的环境配置不是特别的复杂,可是确实有非常多细节须要注意.不然会造成很多配置错误的情况.尽量保证一次配置正确防止重复改动. 网上教程有非常 ...

  2. 从零開始写游戏引擎(一) - project创建以及文件夹设置还有版本号控制

    一句话提要 好的開始等于成功了一半. 创建文件夹结构 project文件夹下最好分为以下几个文件夹 Docs - 开发文档,设计文档 Assets - 角色,动作,模型和音效等 Source - 代码 ...

  3. [Golang] 从零開始写Socket Server(3): 对长、短连接的处理策略(模拟心跳)

    通过前两章,我们成功是写出了一套凑合能用的Server和Client,并在二者之间实现了通过协议交流.这么一来,一个简易的socket通讯框架已经初具雏形了,那么我们接下来做的.就是想办法让这个框架更 ...

  4. [Golang] 从零開始写Socket Server(4):将执行參数放入配置文件(XML/YAML)

    为了将我们写好的Server公布到server上.就要将我们的代码进行build打包.这样假设以后想要改动一些代码的话.须要又一次给代码进行编译打包并上传到server上.     显然,这么做过于繁 ...

  5. [Golang] 从零開始写Socket Server(2): 自己定义通讯协议

    在上一章我们做出来一个最基础的demo后,已经能够初步实现Server和Client之间的信息交流了~ 这一章我会介绍一下怎么在Server和Client之间实现一个简单的通讯协议.从而增强整个信息交 ...

  6. 从零開始的Android新项目7 - Data Binding入门篇

    Data Binding自从去年的Google I/O公布到至今,也有近一年的时间了.这一年来,从Beta到如今比較完好的版本号.从Android Studio 1.3到如今2.1.2的支持,能够说D ...

  7. 站点搭建从零開始(四) server的配置

    原文发表在我的个人站点,欢迎大家訪问~转载请保留本段,或注明原文:http://www.hainter.com/website-primer-4 域名解析设置好了,通常我们就能够訪问我们的网站了,上篇 ...

  8. 从零開始学习OpenCL开发(一)架构

    多谢大家关注 转载本文请注明:http://blog.csdn.net/leonwei/article/details/8880012 本文将作为我<从零開始做OpenCL开发>系列文章的 ...

  9. 关东升的《从零開始学Swift》即将出版

    大家好: 苹果2015WWDC大会公布了Swift2.0,它较之前的版本号Swift1.x有非常大的变化.所以我即将出版<从零開始学Swift><从零開始学Swift>将在&l ...

随机推荐

  1. hive中关键字作为列名的方法

    hive中有很多关键字,直接作为列名,会出错的 例如 下面 user就是关键字,作为字段时报以下错误. 解决方案: 使用·· (ESC下面的那个键,点号)两个符号包裹即可.

  2. nginx 的 autoindex on首页不显示的问题 按照下面几行要写上不然不行

    [root@test html]# vim ../conf/nginx.confworker_processes  1;events {    worker_connections  1024;}ht ...

  3. Yarn概述

    转自:http://liujiacai.net/blog/2014/09/07/yarn-intro/ Yarn是随着hadoop发展而催生的新框架,全称是Yet Another Resource N ...

  4. VB.NET多线程入门

    近期项目中遇到了一个处理速度慢阻塞用户界面操作的问题,因此想用多线程来解决. 在处理数据的循环中,新建线程,在新建的线程中处理数据.多线程同一时候处理数据,以此来达到加速的目的,使用户界面操作变得流畅 ...

  5. jQuery过滤HTML标签并高亮显示关键字的方法

    本文实例讲述了jQuery过滤HTML标签并高亮显示关键字的方法.分享给大家供大家参考.具体如下: jQuery实现网页关键字过滤效果,将需要过滤的文字定义在JavaScript中,可定义多个,不过要 ...

  6. Object Slicing in C++

    In C++, a derived class object can be assigned to base class, but the other way is not possible. cla ...

  7. iOS开发之--FMDB的使用

    在很多时候,我们会用到数据库,我们移动端使用的数据库,一般都是嵌入型数据库,是一种较轻型的数据库, 一般很多时候,大牛封装的FMDB的第三方,已经足够满足我们的需求了! 现在分享一下自己的学习心得,希 ...

  8. Android 模拟机出现Installation failed due to invalid URI!错误

    [2017-03-28 09:52:13 - DataVDemo06] Installation failed due to invalid URI![2017-03-28 09:52:13 - Da ...

  9. Zabbix-3.0.x使用OneAlert发送告警

    导读 OneAlert 是国内首个 SaaS 模式的云告警平台,集成国内外主流监控/支撑系统,实现一个平台上集中处理所有 IT 事件,提升 IT 可靠性.它能以史上第二快的速度,对事件进行智能的组织. ...

  10. Visual Studio Code 配置 gulp

    原本用的webstorm部署的gulp,后来由于太卡,打算换个编辑器,考虑了一番,之前用的是sublime,配置很是麻烦,最新听说饥人谷老师用的是vsCode,所以打算尝试一下这个编辑器,安装还是很方 ...