你的位置:首页 > 软件开发 > Java > 第八章 企业项目开发

第八章 企业项目开发

发布时间:2016-01-24 23:00:10
注意:本节代码基于《第七章 企业项目开发--本地缓存guava cache》1、本地缓存的问题本地缓存速度一开始高于分布式缓存,但是随着其缓存数量的增加,所占内存越来越大,系统运行内存越来越小,最后系统会被拖慢(这一点与第二点联系起来)本地缓存存于本机,其缓存数量与大小受本机内存 ...

注意:本节代码基于《第七章 企业项目开发--本地缓存guava cache》

1、本地缓存的问题

  • 本地缓存速度一开始高于分布式缓存,但是随着其缓存数量的增加,所占内存越来越大,系统运行内存越来越小,最后系统会被拖慢(这一点与第二点联系起来)
  • 本地缓存存于本机,其缓存数量与大小受本机内存大小限制
  • 本地缓存存于本机,其他机器的访问不到这样的缓存

解决方案:分布式缓存

  • Jboss cache:缓存还存于本机,但是会同步更新到其他机器(解决了第三个问题,解决不了第一和第二个问题),如果缓存机器数量很多,同步更新很耗时
  • memcached:缓存存于其他机器,理论上缓存数量与大小无限(因为集群可伸缩),且不需要同步,所以即使缓存机器数量很多,也无所谓,但是这样就会造成单点故障问题,最简单易行的解决方案是缓存备份,即缓存至少存两份。

 

2、memcached Java客户端的选用

当下常用的三种memcached Java客户端:

  • Memcached Client for Java:memcached官方提供,基于Java BIO实现
  • SpyMemcached:基于Java NIO
  • XMemcached:基于Java NIO,并发性能优于XMemcached,实际上SpyMemcached性能也很高

三者的实验比较结果:

http://xmemcached.googlecode.com/svn/trunk/benchmark/benchmark.html

所以,我们选用XMemcached来实现客户端的编写。

 

3、代码

在原来的代码结构上,我增加了一个ssmm0-cache模块,专门用于放置分布式缓存相关(memcached、redis、spring cache)的代码。

项目整体结构:

第八章 企业项目开发

说明:怎样新建maven项目,并加入原来项目,最后引入eclipse,见第一章《第一章 企业项目开发--maven+springmvc+spring+mybatis+velocity整合》

 

3.1、ssmm0

pom.第八章 企业项目开发第八章 企业项目开发

 1 <??> 2 <project ="http://maven.apache.org/POM/4.0.0" ="http://www.w3.org/2001/ 3   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> 4  5   <modelVersion>4.0.0</modelVersion> 6  7   <groupId>com.xxx</groupId> 8   <artifactId>ssmm0</artifactId> 9   <version>1.0-SNAPSHOT</version> 10  11   <name>ssmm0</name> 12   <packaging>pom</packaging><!-- 父模块 --> 13  14   <!-- 管理子模块 --> 15   <modules> 16     <module>userManagement</module><!-- 具体业务1-人员管理系统 --> 17     <module>data</module><!-- 封装数据操作 --> 18     <module>cache</module><!-- 缓存模块 --> 19   </modules> 20  21   <properties> 22     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 23     <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> 24   </properties> 25  26   <!-- dependencyManagement不会引入实际的依赖,只是作为一个依赖池,供其和其子类使用 --> 27   <dependencyManagement> 28     <dependencies> 29       <!-- json --> 30       <dependency> 31         <groupId>com.alibaba</groupId> 32         <artifactId>fastjson</artifactId> 33         <version>1.1.39</version> 34       </dependency> 35       <!-- servlet --> 36       <dependency> 37         <groupId>javax.servlet</groupId> 38         <artifactId>javax.servlet-api</artifactId> 39         <version>3.0.1</version> 40         <scope>provided</scope> 41       </dependency> 42       <!-- spring --> 43       <dependency> 44         <groupId>org.springframework</groupId> 45         <artifactId>spring-core</artifactId> 46         <version>3.2.6.RELEASE</version> 47       </dependency> 48       <dependency> 49         <groupId>org.springframework</groupId> 50         <artifactId>spring-beans</artifactId> 51         <version>3.2.6.RELEASE</version> 52       </dependency> 53       <dependency> 54         <groupId>org.springframework</groupId> 55         <artifactId>spring-context</artifactId> 56         <version>3.2.6.RELEASE</version> 57       </dependency> 58       <dependency> 59         <groupId>org.springframework</groupId> 60         <artifactId>spring-web</artifactId> 61         <version>3.2.6.RELEASE</version> 62       </dependency> 63       <dependency> 64         <groupId>org.springframework</groupId> 65         <artifactId>spring-webmvc</artifactId> 66         <version>3.2.6.RELEASE</version> 67       </dependency> 68       <!-- 这个是使用velocity的必备包 --> 69       <dependency> 70         <groupId>org.springframework</groupId> 71         <artifactId>spring-context-support</artifactId> 72         <version>3.2.6.RELEASE</version> 73       </dependency> 74       <!-- mysql --> 75       <dependency> 76         <groupId>mysql</groupId> 77         <artifactId>mysql-connector-java</artifactId> 78         <version>5.1.27</version> 79         <scope>runtime</scope> 80       </dependency> 81       <!-- 数据源 --> 82       <dependency> 83         <groupId>org.apache.tomcat</groupId> 84         <artifactId>tomcat-jdbc</artifactId> 85         <version>7.0.47</version> 86       </dependency> 87       <!-- mybatis --> 88       <dependency> 89         <groupId>org.mybatis</groupId> 90         <artifactId>mybatis</artifactId> 91         <version>3.1.1</version> 92       </dependency> 93       <dependency> 94         <groupId>org.mybatis</groupId> 95         <artifactId>mybatis-spring</artifactId> 96         <version>1.1.1</version> 97       </dependency> 98       <!-- velocity --> 99       <dependency>100         <groupId>org.apache.velocity</groupId>101         <artifactId>velocity</artifactId>102         <version>1.5</version>103       </dependency>104       <dependency>105         <groupId>velocity-tools</groupId>106         <artifactId>velocity-tools-generic</artifactId>107         <version>1.2</version>108       </dependency>109       <!-- 用于加解密 -->110       <dependency>111         <groupId>commons-codec</groupId>112         <artifactId>commons-codec</artifactId>113         <version>1.7</version>114       </dependency>115       <dependency>116         <groupId>org.bouncycastle</groupId>117         <artifactId>bcprov-jdk15on</artifactId>118         <version>1.47</version>119       </dependency>120       <!-- 集合工具类 -->121       <dependency>122         <groupId>org.apache.commons</groupId>123         <artifactId>commons-collections4</artifactId>124         <version>4.0</version>125       </dependency>126       <!-- 字符串处理类 -->127       <dependency>128         <groupId>org.apache.commons</groupId>129         <artifactId>commons-lang3</artifactId>130         <version>3.4</version>131       </dependency>132       <!-- http -->133       <dependency>134         <groupId>org.apache.httpcomponents</groupId>135         <artifactId>httpclient</artifactId>136         <version>4.2.6</version>137       </dependency>138     </dependencies>139   </dependencyManagement>140 141   <!-- 引入实际依赖 -->142   <dependencies>143     <!-- json -->144     <dependency>145       <groupId>com.alibaba</groupId>146       <artifactId>fastjson</artifactId>147     </dependency>148     <!-- spring -->149     <dependency>150       <groupId>org.springframework</groupId>151       <artifactId>spring-core</artifactId>152     </dependency>153     <dependency>154       <groupId>org.springframework</groupId>155       <artifactId>spring-beans</artifactId>156     </dependency>157     <dependency>158       <groupId>org.springframework</groupId>159       <artifactId>spring-context</artifactId>160     </dependency>161     <!-- 集合工具类 -->162     <dependency>163       <groupId>org.apache.commons</groupId>164       <artifactId>commons-collections4</artifactId>165     </dependency>166     <!-- 字符串处理类 -->167     <dependency>168       <groupId>org.apache.commons</groupId>169       <artifactId>commons-lang3</artifactId>170     </dependency>171   </dependencies>172 173   <build>174     <resources>175       <!-- 这里配置了这一块儿true,才可以让指定文件(这里是src/main/resources/spring-data.176         , 值得注意的是,如果src/main/resources下还有其他文件,而你不想让其读pom.177         如下边的注释那样,否则,会报这些文件找不到的错误 178       -->179       <resource>180         <directory>src/main/resources</directory>181         <filtering>true</filtering>182         <includes>183           <include>*.</include>184           <include>*.properties</include>185         </includes>186       </resource>187       <!-- 188       <resource> 189         <directory>src/main/resources</directory> 190         <filtering>false</filtering>  191         <includes> 192           <include>*.properties</include> 193         </includes> 194       </resource> 195       -->196       <resource> 197         <directory>src/main/resources</directory> 198         <filtering>false</filtering>  199         <includes> 200         <!-- 这里如果不加这一条,那么在spring-data.-->201           <include>mapper/**/*.</include> 202         </includes> 203       </resource> 204     </resources>205   </build>206 207   <!-- 208     profiles可以定义多个profile,然后每个profile对应不同的激活条件和配置信息,从而达到不同环境使用不同配置信息的效果 209     注意两点: 210     1)<activeByDefault>true</activeByDefault>这种情况表示服务器启动的时候就采用这一套env(在这里,就是prod) 211     2)当我们启动服务器后,想采用开发模式,需切换maven的env为dev,如果env的配置本身就是dev,需要将env换成rc或prod,点击apply,然后再将env切换成dev,点击apply才行 212   -->213   <profiles>214     <!-- 开发env -->215     <profile>216       <id>dev</id>217       <activation>218         <!-- 这里为了测试方便,改为了true,在上线的时候一定要改成false,否则线上使用的就是这一套dev的环境了 -->219         <activeByDefault>true</activeByDefault>220         <property>221           <name>env</name>222           <value>dev</value>223         </property>224       </activation>225       <properties>226         <env>dev</env>227 228         <jdbc.driverClassName>com.mysql.jdbc.Driver</jdbc.driverClassName>229         <!--230            对于jdbc.url中内容的配置,如果需要配置 &amp;时,有两种方法:231           1)如下边这样,使用<![CDATA[XXX]]>包起来 232           2)使用jdbc.properties文件来读取此pom.233           在使用后者的时候,注意三点:234           1)需要修改上边的build中的内容 235           2)需要在spring.236           3)将jdbc.properties放在ssmm0-data项目中,之后需要将ssmm0-data项目的env配置为dev 237         -->238         <jdbc.url><![CDATA[jdbc:mysql://127.0.0.1:3306/blog?zeroDateTimeBehavior=convertToNull&amp;useUnicode=true&amp;characterEncoding=utf-8]]></jdbc.url>239         <jdbc.username>root</jdbc.username>240         <jdbc.password>123456</jdbc.password>241         242         <!-- memcache,多台服务器之间需要使用空格隔开,而不要使用英文逗号隔开,因为Xmemcached的AddrUtil源码是根据空格隔开的 -->243         <memcached.servers><![CDATA[127.0.0.1:11211]]></memcached.servers>244         <memcached.max.client>10</memcached.max.client><!-- 最多的客户端数 -->245         <memcached.expiretime>900</memcached.expiretime><!-- 过期时间900s -->246         <memcached.hash.consistent>true</memcached.hash.consistent><!-- 是否使用一致性hash算法 -->247         <memcached.connection.poolsize>1</memcached.connection.poolsize><!-- 每个客户端池子的连接数 -->248         <memcached.op.timeout>2000</memcached.op.timeout><!-- 操作超时时间 -->249       </properties>250     </profile>251     <!-- 预上线env -->252     <profile>253       <id>rc</id>254       <activation>255         <activeByDefault>false</activeByDefault>256         <property>257           <name>env</name>258           <value>rc</value>259         </property>260       </activation>261       <properties>262         <env>rc</env>263 264         <jdbc.driverClassName>com.mysql.jdbc.Driver</jdbc.driverClassName>265         <!-- 假设的一个地址 -->266         <jdbc.url><![CDATA[jdbc:mysql://10.10.10.100:3306/blog?zeroDateTimeBehavior=convertToNull&amp;useUnicode=true&amp;characterEncoding=utf-8]]></jdbc.url>267         <jdbc.username>root2</jdbc.username>268         <jdbc.password>1234562</jdbc.password>269       </properties>270     </profile>271     <!-- 线上env -->272     <profile>273       <id>prod</id>274       <activation>275         <!-- 这里为了测试方便,改为了false,在上线的时候一定要改成true,否则线上使用的就不是这一套环境了 -->276         <activeByDefault>false</activeByDefault>277         <property>278           <name>env</name>279           <value>prod</value>280         </property>281       </activation>282       <properties>283         <env>prod</env>284 285         <jdbc.driverClassName>com.mysql.jdbc.Driver</jdbc.driverClassName>286         <!-- 假设的一个地址 -->287         <jdbc.url><![CDATA[jdbc:mysql://99.99.99.999:3307/blog?zeroDateTimeBehavior=convertToNull&amp;useUnicode=true&amp;characterEncoding=utf-8]]></jdbc.url>288         <jdbc.username>sadhijhqwui</jdbc.username>289         <jdbc.password>zxczkchwihcznk=</jdbc.password>290       </properties>291     </profile>292   </profiles>293 </project>

原标题:第八章 企业项目开发

关键词:

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录