Ubuntu 系统下安装ArcSDE 9.1
虽然ESRI的官方文档如何安装ArcSDE已经很详细了(英文的),而且网上也有很多参考资料,但是这里还是针对自己的习惯以及针对ubuntu,用中文做一下说明,只是为了之后自己方便查阅。
1. 安装环境
我们安装的ArcSDE版本是9.1 for Oracle 10gR2,根据ESRI的官方文档,针对Oracle 9i的可以直接用来给10g,只不过有一些改动。
1. All references to Oracle9i can be changed to Oracle10gR2.
2. All references to the sdesetupora9i command should be substituted with sdesetupora10g.
3. All references to the sdeservice Co create Cd oracle9i,SID command should be substituted with sdeservice Co create Cd oracle10g,SID
4. UNIX installations/System Requirements
The ArcSDE 9.1 for Oracle10gR2 release is available on the following UNIX and Linux platforms:
Solaris 64bit
AIX 64bit
Red Hat Linux
2. 安装前的准备
a. 安装好Oracle 10g,在ubuntu上安装Oracle 10g可以参考我的另一篇文档。
b. 创建并设置好sde用户。
ArcSDE需要一个名为sde的用户,这个用户其他的属性都不重要,所以我将其所属的组设置为admin,以便于使用sudo。
官方文档上说shell应当设置为/bin/sh或者/bin/csh,我这里设置成bash,也可以。
同时,将sde加入oinstall组,是为了使之能运行一些oracle命令,同时使用oracle的一些动态链接库。
创建用户
sudo useradd -g admin -G oinstall -d /home/sde -s /bin/bash -m -k /etc/skel sde
设置密码
sudo passwd sde
输入你为sde用户设置的密码。
然后su sde,登录sde用户,或者直接退出当前用户,用sde用户登录。
c. 设置环境变量。
在.bashrc文件里修改(ubuntu默认.profile文件读取.bashrc文件,而且.bashrc文件在每次登录的时候都会读取),需要设置的环境变量如下:
SDEHOME #ArcSDE安装的地方
ORACLE_HOME #Oracle安装的地方
ORACLE_SID #Oracle SID的值
TNS_ADMIN #tnsnames.ora文件所在的地方
PATH $PATH:$SDEHOME/bin:$ORACLE_HOME/bin
LD_LIBRARY_PATH $SDEHOME/lib:/usr/lib:/lib:$ORACLE_HOME/lib (All platforms except HP and IBM)
SHLIB_PATH $SDEHOME/lib:/usr/lib:/lib:$ORACLE_HOME/lib (for HP only)
LIBPATH $SDEHOME/lib:/usr/lib:/lib:$ORACLE_HOME/lib (for IBM only)
TWO_TASK #value for TWO_TASK (if ArcSDE and Oracle on different machines)
如果Oracle数据库安装在本地,那么ORACLE_HOME和ORACLE_SID是需要设置并且起作用的,而,如果设置了TWO_TASK,那么它们就不起作用。
TWO_TASK指出在远程安装的Oracle的地址。如果在本地安装的Oracle,那么就不需要指出TNS_ADMIN和TWO_TASK。
注意:ArcSDE启动的时候,giomgr进程会读取$SDEHOME/etc/dbinit.sde文件中的设置,这会覆盖掉在.profile文件中的设置。
我的环境变量的设置如下:
umask 022
export ORACLE_BASE=/opt/oracle
export SDEHOME=/home/sde/sdeexe91
export ORACLE_HOME=/opt/oracle
export ORACLE_SID=GISexport PATH=$SDEHOME/bin:$ORACLE_HOME/bin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$SDEHOME/lib:/usr/lib:/lib:$LD_LIBRARY_PATH:$ORACLE_HOME/lib/stubs
d. 创建Oracle数据库用户和tablespace。
i. 创建tablespace。
tablespace至少需要200M的空间,我们这里创建成2G,最大是unlimited。
由于Oracle推荐使用本地管理表空间,那么这里就设置成本地管理。关于本地管理和数据字典管理的定义和比较,请参阅下面的文档:
Locally Managed Tablespaces:
A tablespace that manages its own extents maintains a bitmap in each datafile to keep track of the free or used status of blocks in that data file. Each bit in the bitmap corresponds to a block or a group of blocks. When an extent is allocated or freed for reuse, the Oracle server changes the bitmap values to show the new status of the blocks.
Dictionary-Managed Tablespaces:
For a tablespace that uses the data dictionary to manage its extents, the Oracle server updates the appropriate tables in the data dictionary whenever an extent is allocated or deallocated.
Advantages of Locally Managed Tablespaces:
Locally managed tablespaces have the following advantages over dictionary-managed tablespaces:
Local management avoids recursive space management operations, which can occur in dictionary-managed tablespaces if consuming or releasing space in an extent results in another operation that consumes or releases space in a undo segment or data dictionary table.
Because locally managed tablespaces do not record free space in data dictionary tables, it reduces contention on these tables.
Local management of extents automatically tracks adjacent free space, eliminating the need to coalesce free extents.
The sizes of extents that are managed locally can be determined automatically by the system. Alternatively, all extents can have the same size in a locally managed tablespace.
Changes to the extent bitmaps do not generate undo information because they do not update tables in the data dictionary (except for special cases such as tablespace quota information).
#P#
关于这两种管理方式性能的比较可以参看http://db.rdxx.com/Oracle/2006-5/18/190634694.shtml
创建tablespace的语句是:
CREATE TABLESPACE sde DATAFILE '/opt/oradata/GIS/SDE/SDE.dbf' SIZE 2000M AUTOEXTEND ONNEXT 32M MAXSIZE UNLIMITED LOGGING EXTENT MANAGEMENT LOCAL UNIFORM SIZE 1M SEGMENT SPACE MANAGEMENT AUTO; |
在做这部之前,需要用oracle用户登录,然后在/opt/oradata/GIS/下创建SDE文夹。
其中,EXTENT MANAGEMENT LOCAL是指本地管理方式,UNIFORM 是指对于一个表来说,每次增加分配的空间大小(extent的大小)。
而NEXT是指对于tablespace来说,每次空间不够的时候再次分配的大小。
这里有一段话,可以表明这两者的一些区别:
“每次分配extent时是一个消耗资源的操作,当然是分配次数越少越好。在有些情况下,这也会直接影响性能。例如,在执行批量插入时,如果你的 extent太小,很快就要用完,就得再分配下一个,这时insert进程就只能等待系统去分配下一个extent.在这种情况下分配大一点的 extent会有助于提高性能。另外一点是extent是由连续的block组成的,extent大的话,数据存放会比较集中。这对于顺序读可能有利,但对于随机读则不见得有什么好处。并且现在数据文件基本上都是放在存储上,存储已经把空间分散到不同的磁盘上了。即使在oracle看来是连续的空间,在存储上实际也可能是分散的。
如果你的表确实很大,那就分配大一些的extent,如果表比较小就分配小一些的extent.”
我的理解是,如果tablespace的空间不足了,那么分配NEXT标明的大小。在tablespace空间足够的情况下,在往tablespace中的table里插入数据的时候,如果一次插入的数据大于UNIFORM的值,那么就需要再次分配UNIFORM规定的大小。
所以,如果每次插入的数据量比较大,那么可以考虑UNIFORM的值大一些。
SEGMENT SPACE MANAGEMENT应当设置为AUTO,这个网页http://www.databasejournal.com/features/oracle/article.php/1576991
阐述了为什么设置成AUTO的好处。
其余参数可以参看Oracle的说明,这里推荐一个网页:http://www.psoug.org/reference/tablespaces.html
同时,这里有两幅Oracle提供的图,能够很清楚的看出如何创建和修改tablespace。
创建tablespace:
修改tablespace:
ii. 创建sde用户。
使用sqlplus,创建的sql语句是:
CREATE USER sde IDENTIFIED BY 你的密码 DEFAULT TABLESPACE sde TEMPORARY TABLESPACE TEMP; |
创建用户的sql语句很简单,关于其参数可以参看这个网页http://www.psoug.org/reference/user.html
#P#
3. 安装
a. 下载和解压
从http://support.esri.com/index.cfm?fa=downloads.patchesServicePacks.viewPatch&PID=19&MetaID=1155
下载ArcSDE 9.1 for Oracle10gR2,如果你还想打补丁,那么也在附近的网页找找,下载相应的补丁文件。
打补丁的方法本文不涉及,非常简单,稍微看一下就会了。
解压下载的sde91-ora10gR2-lx.tar.Z文件,由于ubuntu没有compress命令,所以不能用tar Zxvf xxx.tar.Z解压。
应当先uncompress sde91-ora10gR2-lx.tar.Z得到sde91-ora10gR2-lx.tar文件
然后再tar xvf sde91-ora10gR2-lx.tar 即可。
貌似也可以用gunzip解压,请参看其manual查阅解压参数。
解压之后会得到安装文件以及一些必要的文档,其实参看这些附带的文档就可以很好的完成安装,不必看我这篇文章。
b. 安装
进入解压之后的文件夹
cd linux/oracle10g/
运行
./install -load
如果你的LANG环境变量不是英语,那么就会出现一个提示,然你看目前显示的语言是否可以读(不是乱码),我的local设置的是zh_CN.UTF-8
所以出来乱码,我也不知道怎么能让显示中文正常,所以就输入no,用英文显示。
首先需要同意license,必然是yes。
接下来需要注意的是选择CD-ROM 挂载点,因为ArcSDE默认为是从光驱安装的,所以,在这里只要输入ArcSDE安装文件所在的位置就可以了。
我的是/home/sde/linux/oracle10g。
接下来输入要安装的位置,我的是/home/sde
然后接下来自己看自己需要的选择,因人而异,我一路回车下来的。
如果在安装的过程中,想回到上一个选项,那么输入'^'。
之后在/home/sde下面有sdeexe91文件夹,里面是安装的文件。
4. Post Installation
也即安装完成之后到启动服务之前的配置。
a. 设置SDE的配置文件。
修改/etc/services文件,加入:
esri_sde 5151/tcp # ArcSDE service on pinetree
但是对于ubuntu来说,5151这个端口被占用了,如下:
pcrd 5151/tcp # PCR-1000 Daemon
那么可以修改pcrd的端口,也可以修改sde的端口。在这里,我们修改pcrd的端口号为5152。
sde的服务名称为esri_sde,也可以改为别的,我们这里就用它。
同时修改$SDEHOME/etc/services.sde,也加入:
esri_sde 5151/tcp # ArcSDE service on pinetree
同时还可以根据需要修改$SDEHOME/etc下的其他文件。
dbinit.sde #正如前面提到的,这个文件下的参数会覆盖掉.profile或者.cshrc文件下的参数。设置的方法是set (variablename)=(value)
giomgr.defs #这个文件定义了sde服务器如何运行的一些参数,默认的参数在大部分情况下已经够用了。
#如何设置,请参阅ArcSDE Configuration and Tuning Guide for Oracle(安装包里附带的一个pdf文件)。
#在执行了sdesetupora10g命令之后,这个文件里的参数会被读入数据库,生成一个名为server_config的表。
#如果想要在运行了sdesetupora10g命令之后修改参数,请参阅sdeconfig命令。
dbtune.sde #这个文件定义了数据库中表的物理存储参数。同样参阅ArcSDE Configuration and Tuning Guide for Oracle文档。
#运行了sdesetupora10g命令之后,这个文件里的参数会被读入数据库,生成一个名为dbtune的表。
#如果想要在运行了sdesetupora10g之后修改参数,请参阅sdedbtune命令。
#sdeconfig命令和sdedbtune命令都可以在ArcSDE Administration Command Reference(安装包里附带的html和chm文件)中找到详细说明。
b. 修改数据库执行权限。
用sqlplus登录数据库,运行下面的命令:
grant execute on dbms_pipe to public;
grant execute on dbms_lock to public;
同时还需要修改数据库中sde用户的权限,需要给它加入下面的权限:
ALTER ANY INDEX
ALTER ANY TABLE
ANALYZE ANY
CREATE ANY INDEX
CREATE ANY PROCEDURE
CREATE ANY SEQUENCE
CREATE ANY TRIGGER
CREATE ANY VIEW
CREATE SESSION
CREATE TABLE
CREATE PROCEDURE
CREATE SEQUENCE
CREATE TRIGGER
DROP ANY INDEX
DROP ANY TABLE
DROP ANY VIEW
DROP ANY PROCEDURE
DROP ANY SEQUENCE
EXECUTE ANY PROCEDURE
SELECT ANY SEQUENCE
SELECT ANY TABLE
UNLIMITED TABLESPACE
具体的命令是:
GRANT ALTER ANY INDEX TO sde ;
GRANT ALTER ANY TABLE TO sde ;
GRANT ANALYZE ANY TO sde ;
GRANT CREATE ANY INDEX TO sde ;
GRANT CREATE ANY PROCEDURE TO sde ;
GRANT CREATE ANY SEQUENCE TO sde ;
GRANT CREATE ANY TRIGGER TO sde ;
GRANT CREATE ANY VIEW TO sde ;
GRANT CREATE SESSION TO sde ;
GRANT CREATE TABLE TO sde ;
GRANT CREATE PROCEDURE TO sde;
GRANT CREATE SEQUENCE TO sde ;
GRANT CREATE TRIGGER TO sde ;
GRANT DROP ANY INDEX TO sde ;
GRANT DROP ANY TABLE TO sde ;
GRANT DROP ANY VIEW TO sde ;
GRANT DROP ANY PROCEDURE TO sde ;
GRANT DROP ANY SEQUENCE TO sde ;
GRANT EXECUTE ANY PROCEDURE TO sde ;
GRANT SELECT ANY SEQUENCE TO sde ;
GRANT SELECT ANY TABLE TO sde ;
GRANT UNLIMITED TABLESPACE TO sde ;
在安装完成之后,为了安全起见,还需要撤销sde用户的一些权限,如下:
REVOKE ALTER ANY INDEX FROM sde ;
REVOKE ALTER ANY TABLE FROM sde ;
REVOKE ANALYZE ANY FROM sde ;
REVOKE CREATE ANY INDEX FROM sde ;
REVOKE CREATE ANY TRIGGER FROM sde ;
REVOKE CREATE ANY VIEW FROM sde ;
REVOKE DROP ANY INDEX FROM sde ;
REVOKE DROP ANY TABLE FROM sde ;
REVOKE DROP ANY VIEW FROM sde ;
REVOKE DROP ANY PROCEDURE FROM sde ;
REVOKE DROP ANY SEQUENCE FROM sde ;
REVOKE EXECUTE ANY PROCEDURE FROM sde ;
REVOKE SELECT ANY SEQUENCE FROM sde ;
这步做不做都可,对于不同的应用,个人有不同的选择。
c. 执行sdesetupora10g命令。
这个命令的作用是在数据库中生成相应的地理信息数据表,以及一些元数据表,同时设置ArcSDE存储的方式等。
要启动sde服务,这个命令必须执行成功。
sdesetupora10g的执行参数是:
-?
-h
-o upgrade [-H (sde_directory)] [-u (DB_Admin_user)] [-p (DB_Admin_password)] [-D (database)] [-s datasource] [-l (key)] [-N] [-q]
-o list [-H (sde_directory)] [-u (DB_Admin_user)] [-p (DB_Admin_password)] [-D (database)] [-s datasource] [-q]
-o install [-H (sde_directory)] [-u (DB_Admin_user)] [-p (DB_Admin_password)] [-D (database)] [-s datasource] [-l (key)] [-N] [-q]
-o update_key -l (key) [-u (DB_Admin_user)] [-p (DB_Admin_password)] [-D (database)] [-H (sde_directory)][-s datasource] [-N] [-q]
我们这里是第一次执行,而且是安装,所以用-o install参数。-o list参数列出所安装的ArcSDE版本。
这个命令的详细信息可参看ArcSDE Administration Command Reference。
运行命令:
sdesetupora10g -o install -u sde -p 你的密码
如果最后显示Successfully installed ArcSde.
那么恭喜你,最重要和最困难的一步完成了。
#P#
5. 认证
ArcSDE是收费软件,那么必然需要一个认证文件来确保你是正确合法的购买的ArcSDE,而且正确的使用。
对于我们中国人来说,对外国的版权费早在清朝的时候已经交过了,所以放心的使用“盗版”吧,不过不要让他们发现就好。
认证文件是一个.ecp文件,要用sdesetupora10g命令的-o update_key参数来注册。
其实也可以在上面安装的一步,-o install的时候,附加上-l参数来注册。
命令是:
sdesetupora10g -o update_key -l 你的.ecp文件 -u sde -p 你的密码
6. 启动ArcSDE服务
命令sdemon -o start
会让你输入
Please enter ArcSDE DBA password:
输入相应密码。
如果显示:
ArcSDE Instance esri_sde started Mon Jul 14 21:53:54 2008
而且sdemon -o status
显示的是Accepting Connections
那么恭喜你,服务已经启动了。
如果要设置随着机器自动启动,那么创建sde.sh文件,加入下面的内容:
#!/bin/sh
#
SDEHOME=/home/sde/sdeexe91
SDE_OWNR=sde
ORACLE_HOME=/opt/oracle
#
#
if [ ! -d $SDEHOME ] || [ ! -f $SDEHOME/bin/sdemon ]
then
echo "ArcSDE startup: cannot start"
exit 1
fi
#
case "$1" in
start)
#ArcSDE startup
echo -n "Starting ArcSDE: "
su $SDE_OWNR -c "export ORACLE_BASE=/opt/oracle &&
export SDEHOME=/home/sde/sdeexe91 &&
export ORACLE_HOME=/opt/oracle &&
export ORACLE_SID=GIS &&
export PATH=$SDEHOME/bin:$ORACLE_HOME/bin:$PATH &&
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$SDEHOME/lib:/usr/lib:/lib:$LD_LIBRARY_PATH:$ORACLE_HOME/lib/stubs &&
$SDEHOME/bin/sdemon -o start -p gis123"
touch /var/lock/sde
echo "OK, Started"
;;
stop)
#ArcSDE shutdown
echo -n "Shutdown ArcSDE: "
su $SDE_OWNR -c "export ORACLE_BASE=/opt/oracle &&
export SDEHOME=/home/sde/sdeexe91 &&
export ORACLE_HOME=/opt/oracle &&
export ORACLE_SID=GIS &&
export PATH=$SDEHOME/bin:$ORACLE_HOME/bin:$PATH &&
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$SDEHOME/lib:/usr/lib:/lib:$LD_LIBRARY_PATH:$ORACLE_HOME/lib/stubs &&
$SDEHOME/bin/sdemon -o shutdown -p gis123"
rm -f /var/lock/sde
echo "OK, Stopped"
;;
restart)
$0 stop
$0 start
;;
*)
echo "Usage: $0 start|stop|restart"
exit 1
;;
esac
exit 0
然后:
chmod 755 sde.sh
sudo cp sde.sh /etc/init.d/
sudo update-rc.d sde.sh defaults 99
就可以了。