Centos6下SVN服务器(结合Apache)的搭建

一、什么是 Subversion?

(本文永久地址:http://woymk.blog.51cto.com/10000269/1951937)

Subversion 是一个免费/开源的版本控制系统(version control system, VCS), 也就是说, Subversion 可以跨越时间地对文件和目录, 以及它们的修改进行管理. 这就允许你恢复数据的旧版本, 或检查数据的修改历史. 由于这个特点, 很多人把版本控制系统看成是一种“时间机器”。

 

Subversion 可以跨越网络进行操作, 这就允许多个用户在不同的机器上工作. 从某种程度上讲, 允许用户在各自的空间里修改和管理同一组数据可以促进团队协作, 因为修改不再是单线进行, 开发速度会更快. 由于所有的工作都被记录在案, 也就不用担心并行开发会降低软件的质量—如果出现不正确的修改, 只要撤消那一次更改操作即可。

 

某些版本控制系统同时也是软件配置管理 (software configuration management, SCM) 系统. 这种系统经过精巧的设计, 专门用于管理源代码树, 具备许多与软件开发有关的特性—理解编程语言, 提供了程序构建工具. 但 Subversion 不是 SCM, 它是一个通用系统, 可以管理任意类型的文件集合. 对你来说, 这些文件可能是源代码文件—对别人来说, 可能是一个货物清单或数字电影。

 

二、Subversion 的架构

Centos6下SVN服务器(结合Apache)的搭建

 

图中的一端是存放所有版本数据的 Subversion 仓库, 另一端是 Subversion 客户端程序, 客户端程序管理着部分版本数据在本地的映射. 两端之间是穿过仓库访问 (Repository Access) 层的多条访问路径, 其中一些路径跨越计算机网络, 通过网络服务器对仓库进行访问, 其他一些路径则不经过网络, 直接访问仓库.

 

三、Subversion 的组件

svn

客户端命令行工具

 

svnversion

用于报告工作副本状态 (就项目的版本号而言) 的工具

 

svnlook

可以直接检查仓库的工具

 

svnadmin

用于创建, 调整或修复 Subversion 仓库的工具

 

mod_dav_svn

Apache HTTP 服务器插件, 该插件允许用户通过网络访问仓库

 

svnserve

一个定制的, 可独立运行的服务器程序, 可以以守护进程方式运行, 也可以被 SSH 调用, 这是另一种允许用户通过网络访问仓库的方法

 

svndumpfilter

过滤 Subversion 仓库转储数据流的程序

 

svnsync

可以跨越网络对仓库进行增量镜像备份的程序

 

svnrdump

可以跨越网络对仓库历史进行转储和加载的程序

 

svnmucc

该工具支持在没有工作副本的情况下, 在一个单独的提交中对多个仓库执行基于 URL 的操作

 

四、安装Subversion前的准备

 

安装一些常用的依赖包

yum install -y make gcc gcc-c++ perl zlib-devel libaio libpng libpng-devel libjpeg-devel pcre-devel

yum install -y  libXpm-devel openssl openssl-devel libxml2-devel bzip2-devel.x86_64 libjpeg-turbo-devel

yum install -y  freetype freetype-devel libtool cmake ncurses-devel bison re2c curl-devel wget

rpm -ivh "http://mirrors.sohu.com/fedora-epel/epel-release-latest-6.noarch.rpm"

yum install -y libmcrypt-devel re2c unzip

 

安装Subversion需要的依赖包

(详情可参考官方文档:http://svn.apache.org/repos/asf/subversion/trunk/INSTALL)

 

1. Apache Portable Runtime 1.3 or newer

cd /usr/localhost/src

wget https://mirrors.tuna.tsinghua.edu.cn/apache/apr/apr-1.5.2.tar.gz

wget https://mirrors.tuna.tsinghua.edu.cn/apache/apr/apr-util-1.5.4.tar.gz

tar zxvf apr-1.5.2.tar.gz

cd apr-1.5.2

./configure --prefix=/usr/local/apr

make && make install

cd ..

tar zxvf apr-util-1.5.4.tar.gz

cd apr-util-1.5.4

./configure --prefix=/usr/local/apr --with-apr=/usr/local/apr

make && make install

 

2. Zlib

http://www.zlib.net/

下载的当前版本为zlib-1.2.11.tar

解压后执行 

./configure

make && make install

 

3. autoconf 2.59 or newer

yum install autoconf –y

 

4. libtool 1.4 or newer

yum install libtool -y

 

5. Apache Serf library 1.3.4 or newer

cd /usr/local/src

wget http://archive.apache.org/dist/serf/serf-1.2.1.tar.bz2

tar jxvf serf-1.2.1.tar.bz2

cd serf-1.2.1

yum install expat   expat-devel –y

./configure --prefix=/usr/local/serf --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr

make && make install

 

6. OpenSSL (OPTIONAL)

yum install openssl –y

 

7. Berkeley DB 4.X  (可选安装)

 yuminstall db4 -y

 

8. Cyrus SASL library (OPTIONAL)

yum -y install cyrus-sasl*

 

9.  dbus

   yum install dbus

 

10.  Qt 4  (可选安装)

   yum install qt  qt-devel

 

11. GLib 2  (Unix only, OPTIONAL)

   yum install  glib2  glib2-devel

 

12. KDELibs 4  (可选安装)

   yum install kdelibs  kdelibs-devel

 

13. Python 2.7 or newer (https://www.python.org/)

  (可选择安装)

 

14. SQLite (REQUIRED)

https://www.sqlite.org/download.html

cd /usr/local/src

wget http://www.sqlite.org/2017/sqlite-amalgamation-3180000.zip

unzip sqlite-amalgamation-3180000.zip

先解压好,后面安装Subversion时要用到

五、安装Apache Web Server(2.2.X or newer)

下载源码包

cd /usr/local/src

wget http://mirrors.sohu.com/apache/httpd-2.2.34.tar.gz

tar zxvf httpd-2.2.34.tar.gz

编译&&安装

cd httpd-2.2.34

./configure --prefix=/webapp/apache2  --enable-dav --enable-dav-fs--enable-dav-lock  --enable-so --enable-rewrite  --enable-modules=all  --enable-mods-shared=all  --with-mpm=prefork  --enable-maintainer-mode  --enable-ssl --with-ssl  --with-pcre  --with-include-apr

make && make install

 

配置apache

cd /webapp/apache2/

vi conf/httpd.conf

 

找到

#ServerName www.example.com:80

改成

ServerName localhost:80

 

检查配置文件语法

bin/apachectl -t

 

配置启动脚本

cp /usr/local/src/httpd-2.2.34/build/rpm/httpd.init/etc/init.d/httpd

 

注意文件中有三处主要的地方需要修改下的:

httpd=${HTTPD-/webapp/apache2/bin/httpd}

pidfile=${PIDFILE-/webapp/apache2/logs/${prog}.pid}

CONFFILE=/webapp/apache2/conf/httpd.conf

请根据自己的安装目录更改相应的路径!

 

然后运行如下命令:

chmod +x /etc/init.d/httpd

chkconfig --add httpd

chkconfig httpd on

/etc/init.d/httpd start

netstat -lnp |grep httpd

六、安装Subversion

官网下载地址:http://subversion.apache.org/download.cgi

这里我们下载1.8版

cd /usr/local/src

wget http://mirrors.tuna.tsinghua.edu.cn/apache/subversion/subversion-1.8.18.tar.gz

tar zxvf subversion-1.8.18.tar.gz

 

把解压好的SQLite复制到subversion目录下

mv sqlite-amalgamation-3180000subversion-1.8.18/sqlite-amalgamation

 

cd subversion-1.8.18

./configure --prefix=/webapp/subversion --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr --enable-mod-activation --with-apache-libexecdir=/webapp/apache2/modules   --with-apxs=/webapp/apache2/bin/apxs --with-serf=/usr/local/serf  --with-zlib

make && make install

 

创建版本库:

要创建一个版本库,首先要确定采用哪种数据存储方式。在 Subversion 中,版本库的数据存储有两种方式,一种是在 Berkeley DB 数据库中存放数据;另一种是使用普通文件,采用自定义的格式来储存,称为 FSFS。

 

两种版本库数据存储对照表

特性 Berkeley DB FSFS
对操作中断的敏感 很敏感;系统崩溃或者权限问题会导致数据库“塞住”,需要定期进行恢复。 不敏感。
可只读加载 不能 可以
存储平台无关 不能 可以
可从网络文件系统访问 不能 可以
版本库大小 稍大 稍小
可扩展性:修订版本树的数量 数据库,没有限制 许多古老的本地文件系统在处理单一目录包含上千个条目时出现问题。
可扩展性:文件较多的目录 较慢 较快
速度:检出最新的代码 较快 较慢
速度: 大的提交 较慢,但是时间被分配在整个提交操作中 较快,但是最后较长的延时可能会导致客户端操作超时
组访问权处理 对于用户的umask设置十分敏感,最好只由一个用户访问。 对umask设置不敏感
功能成熟时间 2001年开始使用 2004年开始使用

确定了具体的数据存储类型,只要在命令行当中执行 svnadmin 命令就可以创建一个 Subversion 版本库,命令如下:

创建文件夹

mkdir /webapp/svndata

PATH=$PATH:/webapp/subversion/bin


执行svnadmin命令创建版本库,指定数据存储为FSFS

svnadmin create --fs-type fsfs /webapp/svndata/data


如果要指定为Berkeley DB,则将fsfs替换为bdb

对于Subversion 1.2以后版本,svnadmin缺省使用fsfs文件系统后端创建版本库。 

ll /webapp/svndata/data/

总用量 24

drwxr-xr-x. 2 root root 4096 7月  28 07:29 conf

drwxr-sr-x. 6 root root 4096 7月  28 07:29 db

-r--r--r--. 1 root root    2 7月  28 07:29 format

drwxr-xr-x. 2 root root 4096 7月  28 07:29 hooks

drwxr-xr-x. 2 root root 4096 7月  28 07:29 locks

-rw-r--r--. 1 root root  246 7月  28 07:29 README.txt

 

conf 目录下存放了版本库的配置文件,包括用户访问控制和权限控制等内容;

db 目录下存放着 Subversion 所要管理的所有受版本控制的数据;

hooks 目录存放着钩子脚本及其模版(一种版本库事件触发程序);

locks 目录存放着 Subversion 版本库锁定数据;

format 文件记录了版本库的布局版本号。

 

用 svn import 命令来进行项目的导入:

svn import /tmp/ file:///webapp/svndata/data/  --message "init"

 

确认导入的项目是否正确:

svn list --verbose file:///webapp/svndata/data/

 

查看最新修订版本的信息:

svnlook info /webapp/svndata/data

 

"--revision 版本号",指定某一个修订版的显示:

svnlook info /webapp/svndata/data --revision1

 

显示版本库的具体树形结构,后面的“--show-ids”选项指定显示每一个显示元素的修改版本 ID:

svnlook tree /webapp/svndata/data/ --show-ids


基本的服务器配置

svnserve 是一个轻量级的服务器, 使用自定义的协议通过TCP/IP与客户端通讯。客户端通过由 svn:// 或者 svn+ssh:// 开始的URL访问svnserve服务器。


启动SVN服务器:

svnserve –d -r /webapp/svndata

 

-i作为 inetd 启动

-d做为守护进程启

-r用来指定版本库的根路径

 

在客户端使用 TortoiseSVN 可以通过如下形式访问服务器:

svn://服务器IP/data

 

版本库的 conf 子文件夹下的配置文件说明:

1.svnserve.conf

[general]

# anon-access = read  #匿名用户的权限

# auth-access = write  #认证用户的权限

password-db = passwd  #指定密码文件

# authz-db = authz  #权限控制文件

# realm = My First Repository

 

2.passwd文件的配置及说明

 

[users]

# harry = harryssecret

# sally = sallyssecret

 

等号前面是用户名,后面是密码,密码是明文的。更改svnserve.conf的时候,需要重启SVN,更改authz,passwd文件,不需重启。

 

3.authz文件的配置及说明

 

[groups]

# harry_and_sally = harry,sally

 

groups定义的变量就是组名,1个用户组可以包含1个或者多个用户,逗号分隔,上例中harry_and_sally就是一个组

 

版本库目录格式:

[<版本库>:/项目/目录]

@<用户组名> = <权限>

<用户名> = <权限>

 

其中,方框号内部可以有多种写法:

 

[/],表示根目录及以下,根目录是svnserve启动时指定的,这里配置的是/webapp/svndata/,[/]就是表示对全部版本库设置权限。

[data:/],表示对版本库data设置权限

[date:/test],表示对版本库data中的test项目设置权限

[data:/test/aaa],表示对版本库data中test项目的aaa目录设置权限

权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。

权限可以是w、r、rw、和空,空表示没有任何权限。

authz中每个参数都要顶格写,开头不能有空格。

 

[/]

Kevin = rw

@harry_and_sally = r

 

注意:权限配置文件中出现的用户名必须已在用户配置文件中定义

 

设置passwd,authz文件权限

chmod 600 conf/{passwd,authz}      #非必须,最好改下

 

4. Checkout注意事项

在windows上安装客户端TortoiseSVN之后,checkout版本的时候有个地方需要注意。

 

例如如果创建项目版本库的命令为 # svnadmin create /svn/testversion1/

启动svn服务的命令 # svnserve -d -r /svn/

 

那么在客户端检出该版本库的URL为:svn://xx.xx.xx.xx/testversion1/

 

如果启动svn服务的命令为 svnserve -d -r /svn/testversion1/,那么检出的URL则为:svn://xx.xx.xx.xx/

 

七、与 Apache Http Server 的结合

通过 Http 协议访问版本库是 Subversion 的亮点之一。使用 Http 协议意味着只需要打开浏览器,输入 URL 即可轻松的浏览整个版本库。灵活通常带来复杂性,Http 方式相对于 svnserve 方式来说需要更多的配置。

 

配置apache

为了使 Subversion 与 dav 模块通信,需要安装 mod_dav_svn 插件,在Apache的 httpd.conf 文件中加入以下内容:

 

LoadModule dav_module modules/mod_dav.so

LoadModule dav_svn_module modules/mod_dav_svn.so

<Location /data>

    DAV svn

    SVNPath /webapp/svndata/data

</Location>

 

重启apache

/etc/init.d/httpd restart

 

浏览器输入“http://服务器IP/data”

显示:

data- Revision 1: /

这表示mod_dav_svn模块工作正常,如果无法显示,请检查防火墙和SELinx的配置

可以先临时关闭防火墙和SELinx(生产环境请按实际情况配置)

iptables –F

setenforce 0

 

可以使用 SVNParentPath 代替SVNPath,

SVNParentPath /webapp/svndate表示/webapp/svndata下的每个子目录都是一个版本库,可以通过:

 

http://服务器IP/svndata/data1

http://服务器IP/svndata/data2

|

|

|

http://服务器IP/svndata/data10

 

来访问。

 

权限设置:

1.  Apache基本权限设置

最简单的客户端认证方式是通过HTTP基本认证机制,简单的使用用户名和密码来验证一个用户所自称的身份,Apache提供了一个htpasswd工具来管理可接受的用户名和密码 。


cd /webapp

apache2/bin/htpasswd -c svndata/passwd user1

-c 表示新建一个密码文件

vi apache2/conf/httpd.conf

在 Location 标签中加入以下内容:

AuthType Basic

AuthName "svn data"

AuthUserFile /webapp/svndata/passwd

Require valid-user

保存后,重启apache后即可

/etc/init.d/httpd restart

 

可以把"Require valid-user" 替换为"Require user harry sally",表示只有harry和sally可以访问该版本库。

 

2. 用 mod_authz_svn 进行目录访问控制

使用mod_authz_svn模块可以更加细致的设置访问权限。


vi apache2/conf/httpd.conf

查看mod_auth_svn 模块是否加载

LoadModule authz_svn_modulemodules/mod_authz_svn.so

 

增加以下内容

<Location /svndata>

    DAV svn

    SVNParentPath /webapp/svndata

    AuthType Basic

    AuthName "svn data"

    AuthUserFile /webapp/svndata/passwd

    AuthzSVNAccessFile /webapp/svndata/accesspolicy

    Satisfy Any

    Require valid-user

</Location>

 

AuthzSVNAccessFile 指向的是 authz 的策略文件,详细的权限控制可以在这个策略文件中指定,如:

#两个分组:group1,group2

[groups]
group1 = user1, user2
group2 = user3, user4
 
#在根目录下指定所有的用户有读权限
[/]
* = r

#追加group1组用户有读写权限
 
@group1= rw
 
#在data下给予用户user1读写权限
 
[data:/]
user1 = rw
 
#禁止所有用户访问 /private 目录

[/private]
* =

#给group2组用户读权限

@group2= r


如果要对具体每个版本库配置,用如下的语法:

[groups]
project1 = user1, user2
project2 = user3 ,user4
 
[data1:/]
* = r
@ project1 = rw
[data2:/]
* = r
@ project2 = rw

这样项目1的project1组只能对 data1 版本库下的文件具有写权限而不能修改版本库data2,同样项目2的project2组也不能修改data1 版本库的文件。


修改完配置后记得保存重启apache:

/etc/init.d/httpd restart

另外还要修改对应目录的权限,让它们支持apache运行帐号可写

chown -R daemon:daemon /webapp/svndata/data

这个帐号可在apache配置文件httpd.conf中设置:

User daemon

Group daemon

八、测试

SVN服务器安装配置完毕,在客户端使用TortoiseSVN进行测试,结果如下:

Centos6下SVN服务器(结合Apache)的搭建


根据提示输入用户名和密码

Centos6下SVN服务器(结合Apache)的搭建

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


可以认为OpenFeign是Feign的增强版,不同的是OpenFeign支持Spring MVC注解。OpenFeign和Feign底层都内置了Ribbon负载均衡组件,在导入OpenFeign依赖后无需专门导入Ribbon依赖,用做客户端负载均衡,去调用注册中心服务。
为进一步规范小程序交易生态、提升用户购物体验、满足用户在有交易的小程序中便捷查看订单信息的诉求,自2022年12月31日起,对于有“选择商品/服务-下单-支付”功能的小程序,需按照平台制定的规范,在小程序内设置订单中心页。开发者可通过小程序代码提审环节,或通过「设置-基础设置-小程序订单中心path设置」模块设置订单中心页path。1、 新注册或有版本迭代需求的小程序,可在提审时通过参数配置该商家小程序的订单中心页path。2、无版本迭代需求的小程序,可在小程序订单中心path设置入口进行设置。
云原生之使用Docker部署Dashdot服务器仪表盘
本文主要描述TensorFlow之回归模型的基本原理
1.漏洞描述Apache Druid 是一个集时间序列数据库、数据仓库和全文检索系统特点于一体的分析性数据平台。Apache Druid对用户指定的HTTP InputSource没有做限制,并且Apache Druid默认管理页面是不需要认证即可访问的,可以通过将文件URL传递给HTTP InputSource来绕过。因此未经授权的远程攻击者可以通过构造恶意参数读取服务器上的任意文件,造成服务器敏感性信息泄露。2.影响版本Apache Druid &lt;= 0.21.13...
内部类(当作类中的一个普通成员变量,只不过此成员变量是class的类型):一个Java文件中可以包含多个class,但是只能有一个public class 如果一个类定义在另一个类的内部,此时可以称之为内部类使用:创建内部类的时候,跟之前的方法不一样,需要在内部类的前面添加外部类来进行修饰 OuterClass.InnerClass innerclass = new OuterClass().new InnerClass();特点:1.内部类可以方便的访问外部类的私有属性...
本文通过解读国密的相关内容与标准,呈现了当下国内技术环境中对于国密功能支持的现状。并从 API 网关 Apache APISIX 的角度,带来有关国密的探索与功能呈现。作者:罗泽轩,Apache APISIX PMC什么是国密顾名思义,国密就是国产化的密码算法。在我们日常开发过程中会接触到各种各样的密码算法,如 RSA、SHA256 等等。为了达到更高的安全等级,许多大公司和国家会制定自己的密码算法。国密就是这样一组由中国国家密码管理局制定的密码算法。在国际形势越发复杂多变的今天,密码算法的国产化
CENTOS环境Apache最新版本httpd-2.4.54编译安装
Apache HTTPD是一款HTTP服务器,它可以通过mod_php来运行PHP网页。影响版本:Apache 2.4.0~2.4.29 存在一个解析漏洞;在解析PHP时,将被按照PHP后缀进行解析,导致绕过一些服务器的安全策略。我们查看一下配置:读取配置文件,前三行的意思是把以 结尾的文件当成 文件执行。问题就在它使用的是 符号匹配的,我们都知道这个符号在正则表达式中的意思是匹配字符串的末尾,是会匹配换行符的,那么漏洞就这样产生了。 进入容器里,打开index.php,发现如果文件后缀名为 php、
apache Hop现在好像用的人很少, 我就自己写一个问题收集的帖子吧, 后面在遇到什么问题都会在该文章上同步更新
2.启动容器ps:注意端口占用,当前部署在 8080 端口上了,确保宿主机端口未被占用,不行就换其他端口ps:用户名和密码都是 admin,一会用于登录,其他随便填5.下载一个官方提供的样例数据库【可跳过】ps:此步国内无法访问,一般下载不了,能下的就下,不能下的跳过就行了,一会配置自己的数据库7.访问登录页面ps:注意端口是上面自己配置的端口,账号密码是 admin依次点击 Settings → Database Connections点击 DATABASE 就可以配置自己的数据库了
String类的常用方法1. String类的两种实例化方式1 . 直接赋值,在堆上分配空间。String str = "hello";2 . 传统方法。通过构造方法实例化String类对象String str1 = new String("Hello");2.采用String类提供的equals方法。public boolean equals(String anotherString):成员方法 str1.equals(anotherString);eg:publi
下载下载地址http://free.safedog.cn下载的setup:安装点击下面的图标开始安装:可能会提示:尝试先打开小皮面板的Apache服务:再安装安全狗:填入服务名:如果服务名乱写的话,会提示“Apache服务名在此机器上查询不到。”我干脆关闭了这个页面,直接继续安装了。安装完成后,需要进行注册一个账户,最后看到这样的界面:查看配置:...
一、问题描述一组生产者进程和一组消费者进程共享一个初始为空、大小n的缓冲区,只有缓冲区没满时,生产者才能把资源放入缓冲区,否则必须等待;只有缓冲区不为空时,消费者才能从中取出资源,否则必须等待。由于缓冲区是临界资源,它只允许一个生产者放入资源,或一个消费者从中取出资源。二、问题分析(1)、关系分析。生产者和消费者对缓冲区互斥访问是互斥关系,同时生产者和消费者又是一个相互协作的关系,只有生产者生产之后,消费者只能才能消费,它们还是同步关系。(2)、整理思路。只有生产生产者和消费者进程,正好是这两个进程
依赖注入的英文名是Dependency Injection,简称DI。事实上这并不是什么新兴的名词,而是软件工程学当中比较古老的概念了。如果要说对于依赖注入最知名的应用,大概就是Java中的Spring框架了。Spring在刚开始其实就是一个用于处理依赖注入的框架,后来才慢慢变成了一个功能更加广泛的综合型框架。我在学生时代学习Spring时产生了和绝大多数开发者一样的疑惑,就是为什么我们要使用依赖注入呢?现在的我或许可以给出更好的答案了,一言以蔽之:解耦。耦合度过高可能会是你的项目中一个比较
<dependency><groupId>org.apache.velocity</groupId><artifactId>velocity-engine-core</artifactId><version>使用人数最多的版本</version></dependency>importorg.apache.velocity.Template;importorg.apache.velo
Java Swing皮肤包前言:一.皮肤包分享二.皮肤包的使用1.先新建一个项目。2.导入皮肤包1.先导入我们刚刚下载的jar文件,右键项目demo即可2.如果右键没有这个选项,记得调为下图模式3.点击下图蓝色圆圈处4.找到刚刚下载的jar文件,点击打开即可5.我们看一下效果,是不是比原生的好看前言:因为Java Swing自身皮肤包不是很好看,甚至有点丑,怎么让你的界面更加好看,这里就需要用到皮肤包,我发现了一个还不错的皮肤包,让你的界面美观了几个等级。废话不多说。一.皮肤包分享百度网盘分享链接:
一、前言在做Java项目开发过程中,涉及到一些数据库服务连接配置、缓存服务器连接配置等,通常情况下我们会将这些不太变动的配置信息存储在以 .properties 结尾的配置文件中。当对应的服务器地址或者账号密码信息有所变动时,我们只需要修改一下配置文件中的信息即可。同时为了让Java程序可以读取 .properties配置文件中的值,Java的JDK中提供了java.util.Properties类可以实现读取配置文件。二、Properties类Properties 类位于 java.util.Pro
Mybatis环境JDK1.8Mysql5.7maven 3.6.1IDEA回顾JDBCMysqlJava基础MavenJunitSSM框架:配置文件的最好的方式:看官网文档Mybatis1、Mybatis简介1.1 什么是Mybatis如何获得Mybatismaven仓库:中文文档:https://mybatis.org/mybatis-3/zh/index.htmlGithub:1.2 持久化数据持久化持久化就是将程序的数据在持久状态和瞬时状态转