一.使用tomcat遠(yuǎn)程部署
1.1遇到的問題:
項(xiàng)目中需要引用第三方j(luò)ar包,在使用mvn打包項(xiàng)目的時(shí)候,會(huì)報(bào)錯(cuò)'dependencies.dependency.systemPath'for com.dingtalk.api:taobao-sdk-java:jar must be omitted.
問題的原因在于mvn在打包項(xiàng)目的時(shí)候,先加載pom.xml,如果本地倉庫沒有的依賴就會(huì)報(bào)錯(cuò)。
解決辦法:將第三方j(luò)ar包安裝到本地倉庫使用命令:Mvn install:install-file -Dfile=E:\taobao-sdk-java-auto_1479188381469-20200422.jar -DgroupId=taobao-sdk-java -DartifactId=taobao-sdk-java -Dversion=2.0 -Dpackaging=jar在pom依賴中加入war,把項(xiàng)目打成war包,否則會(huì)默認(rèn)是jar包,部署不上去。在tomcat config目錄下配置tomcat-users.xml后,重啟tomcat不行的話,要重啟tomcat服務(wù)。如果能夠成功訪問到http://localhost:8080/manager/html,則證明配置成功找錯(cuò)誤要可以通過tomcat日志信息快速定位錯(cuò)誤的原因,提高解決問題的效率5. 之前一致嘗試不成功的原因是因?yàn)檫@個(gè)項(xiàng)目是復(fù)制之后的項(xiàng)目,idea中的terminal命令行所在的路徑還是之前項(xiàng)目的路徑,之前項(xiàng)目中的pom沒有配置插件,所以導(dǎo)致連接不上。
1.2遠(yuǎn)程部署的配置
(1)加入插件:
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<username>admin</username>
<password>123456</password>
<url>http://47.102.123.186:8095/manager/text</url>
<server>tomcatServer</server> //要與server中的id保持一致
<update>true</update>
<path>/zw</path>//項(xiàng)目名
</configuration>
</plugin>
(2)配置tomcat目錄下tomcat-users.xml配置文件:
<role rolename="admin-gui"/>
<role rolename="manager-gui"/> // 允許訪問html接口(即URL路徑為/manager/html/*)<role rolename="manager-script"/>// 允許訪問純文本接口(即URL路徑為/manager/text/*)
<user username="admin" password="123456" roles="admin-gui,manager-gui,manager-script"/>
//注意!可以給該用戶添加多個(gè)角色,為了遠(yuǎn)程部署,至少需要這個(gè)角色:manager-script,也可以開啟manager-gui用于可視化管理
(3)配置maven 的setting.xml文件在servers標(biāo)簽下配置:
<server>
<id>tomcatServer</id>
<username>admin</username>
<password>123456</password>
</server>
(4)使用命令:mvn tomcat7:deploy
二.使用tomcat的配置文件配置數(shù)據(jù)庫連接配置的具體步驟
需要配置tomcat 的conf目錄下的server.xml,context.xml,web.xml。
具體的配置如下:Server.xml的GlobalNamingResources標(biāo)簽下配置:
`<Resource name="jdbc/DataSource" auth="Container"
type="javax.sql.DataSource"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://192.168.0.1;databaseName=xydi" username="sa"
password="sa"
maxActive="20" //最大連接數(shù)
maxIdle="10"
maxWait="-1"/>`//最長的等待時(shí)間
Context.xml下配置:
<ResourceLink name="jdbc/DataSource" global="jdbc/DataSource"
type="javax.sql.DataSource"/>// 引入server.xml的配置信息
Web.xml下配置:
<resource-ref>
<res-ref-name>jdbc/DataSource</res-ref-name>//與resource的name保持一致
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>`
如果使用的spring框架:
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName" value="java:comp/env/jdbc/DataSource"/>
<property name="expectedType" value="javax.sql.DataSource"/>
</bean>
沒有使用spring框架:
Connection con = null;
Context c = new InitialContext();
DataSource ds = (DataSource) c.lookup("java:/comp/env/jdbc/DataSource");//項(xiàng)目名要與context.xml里面的對應(yīng)
con = ds.getConnection();
總結(jié)
到此這篇關(guān)于maven項(xiàng)目遠(yuǎn)程部署&&使用tomcat配置數(shù)據(jù)庫連接的文章就介紹到這了,更多相關(guān)Maven項(xiàng)目遠(yuǎn)程部署Tomcat數(shù)據(jù)庫連接內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!