一、安装:
  1. 环境要求:
  已安装Java平台,版本为j2sdk1.4.2,环境变量JAVA_HOME设为C:\j2sdk1.4.2;
  2. 下载与运行:
  从Apache网站上下载得到一个压缩的文件james-2.1-bin.zip,大小为4.44M,将此包解压到C:\James\james-2.1下。
  运行分为两种方式:前台直接运行、作为后台服务运行;
  1>前台直接运行:
  在C:\James\james-2.1\bin下运行run.bat
  这是会出现:
  Using PHOENIX_HOME: C:\James\james-2.1
  Using PHOENIX_TMPDIR: C:\James\james-2.1\temp
  Using JAVA_HOME: C:\j2sdk1.4.2
  Phoenix 4.0.1
  James 2.1
  Remote Manager Service started plain:4555
  POP3 Service started plain:110
  SMTP Service started plain:25
  NNTP Service Disabled
  Fetch POP Disabled
  这是就表示James邮件服务以开启,不过Window下不能关闭控制台窗口,否者邮件服务会停止。如要克服此缺点必须使James邮件服务作为作为后台服务运行。
  停止前台运行按Ctrl+C,会出现:
  JVM exiting abnormally. Shutting down Phoenix.
  终止批处理操作吗(Y/N)?
  2>后台服务运行:
  将C:\James\james-2.1\conf目录下的f拷贝到C:\James\james-2.1\bin即包含的目录下,运行:
  -i C:\James\james-2.1\f
  然后在控制面板中开启服务或重启即可。
  卸载后台服务:
  到C:\James\james-2.1\bin即包含的目录下,运行:
  -r C:\James\james-2.1\f
  3.
  二、配置:
  1>服务器端配置(邮件服务器的名字假设叫EmailServer,服务器管理员名Admin)
  首先停止已开启的James邮件服务,然后打开文件C:\James\james-2.1\apps\james\l。
  ? 在l文件中,到Postmaster@localhost,把此项改为Admin@EmailServer,同时,到位于
  <!-- By default, the servername 'localhost' is specified. This can be removed, if required. -->
  - <!--
  -->
  - <!-- Warning: If you are using fetchpop it is important to include the -->
  - <!-- fetched domains in the server name list to prevent looping. -->
  - <servernames autodetect="true" autodetectIP="true">
  - <!-- CONFIRM?
  -->
  <servername> localhost </servername>
  </servernames>
  的localhost,把此项改为EmailServer。这样就可以让其它机器也能访问邮件系统。
  ? DNS配置:到同上文件中<dnsserver>段中的如下程序段:
  - <dnsserver>
  - <servers>
  - <!-- CONFIRM? -->
  - <!-- Enter ip address of your DNS server, one IP address per server -->
  - <!-- element. The default configurati
on assumes a DNS server on the localhost. -->
  <server>127.0.0.1</server>
  </servers>
  <authoritative>false</authoritative>
  </dnsserver>
  将127.0.0.1的位置填入DNS服务器的IP地址;
  ? 修改管理员密码:
  到同上文件中的<administrator_accounts>段,如下程序段
  - <administrator_accounts>
  - <!-- CHECKME!
  -->
  - <!-- Change the default login/password.
  -->
  <account login="root" password="root" />
  </administrator_accounts>
  将默认用户名root与密码root修改为需要的值
  ? 修改telnet管理程序登录端口 :(默认为4555)
  到同上文件中的<remotemanager>段下的port如下程序段
  - <remotemanager>
  <port>4555</port>
  - <!-- Uncomment this if you want to bind to a specific inetaddress
  -->
  - <!--
  将<port>4555</port>之间的端口号4555改为需要的端口。
  2> 客户端配置:(略)
  3> 帐号管理
  James的账号管理是通过telnet完成的,登录命令为:
  telnet EmailServer 4555
  其中EmailServer也可以换成IP,4555是端口号。登录时需要用户名和密码,开始默认的用户名和密码均为root。若登录成功,提示如下:
  JAMES Remote Administration Tool 2.1
  Please enter your login and password
  Login id:
  此时输入root用户名,然后会出现:
  Password:
  输入密码root
  注意:在有些操作系统如Windows2000上,用户输入均不显示。
  telnet命令列表:
  help
  显示帮助
  Listusers
  列出目前存在的账户
  Countusers
  显示目前存在的账户的数量
  addusers [用户名] [密码]
  添加新用户
  verify [用户名]
  验证特定用户是否存在
  deluser [用户名]
  删除已存在用户
  setpassword [用户名] [密码]
  设置某一用户的密码
  setalias [别名] [用户名]
  从本地将[别名]的所有邮件转寄[用户名]
  unsetalias [别名]
  取消setalias设置
  setforwarding [用户名] [email地址]
  将[用户名]的邮件转寄指定[email地址]
  unsetforwarding [用户名]
  取消setforwarding设置
  user [资源]
  变为另一用户的资源
  shutdown
  停止当前James邮件服务的JVM程序(对于James为后台服务时,用此命令很方便)
  Quit
  断开telnet连接
  4>用户信息的数据库存储
  James邮件用户的用户信息默认保存在apps\james\var\users目录下,通过修改配置文件apps\james\l,可以把用户信息保存到数据库中,配置方法如下:
  假
设使用的是MySQL数据库:
  第一步:首先将MySQL的驱动程序(例如:mysql-connector-java-3.1.6-bin.jar)考到james的lib目录下(例如:D:\james\lib)
  第二步:在MySQL中新建一个数据库mail;
  第三步:打开l,到<users-store>这一项,此面默认的内容为:
  <repository name="LocalUsers" class="org.apache.james.userrepository.UsersFileRepository">
  <destination URL="file://var/users/"/>
  </repository>
  需要修改为:
  <repository name="LocalUsers"
  class="org.apache.james.userrepository.JamesUsersJdbcRepository" destinationURL="db://maildb/users">
  <sqlFile>file://l</sqlFile>
  </repository>
  其实如不修改也行,因为文件下面也有实例,不过是用<!-- 和 --> 注释掉的,打开即可;记住把
  <repository name="LocalUsers" class="org.apache.james.userrepository.UsersFileRepository">
  <destination URL="file://var/users/"/>
  </repository>
  用<!-- 和 --> 注释掉;
  通过修改,我们就把用户信息的存储介质从file改成了db,<sqlFile>是指明了在db中的数据表结构及相关数据库信息。
  第四步:仍然是l,到<data-sources>项,默认内容为空,把此项内容修改为:
  <data-source name="maildb" class="org.apache.dred.JdbcDataSource">
  <driver>sql.Driver</driver>
  <dburl>jdbc:mysql://127.0.0.1/mail</dburl>
  <user>root</user>
  <password></password>
  <max>20</max>
  </data-source>
  或打开文件下面实例的<!-- 和 --> 注释
  <driver>是指MySQL的JDBC驱动,注意这个默认的<driver>是有问题的,要改成MySQL的驱动程序中Driver.class的路径,即:
  <driver&sql.jdbc.Driver</driver>
  <dburl>指数据库的访问路径,IP后的mail即MySQL中新建数据库名,接下来是用户名、密码及最大连接数。
  再次启动时,james将在mail数据库中自动创建有关用户的表格。
  至此,数据库配置完成,启动James,若正常无误,请通过telnet添加一个新用户,比如adduser holen 123456,然后检查MySQL中的mail数据库,下面将有一个表users,这是James根据file://l的内容创建的。
  通过以上配置,James的用户信息就可以保存在数据库中了。
  注:修改以前的账户会丢失!
  一、FAQ
  1、 在启动james时,提示POP3或SMTP不能使用?
  请检查一下,看“管理工具—>服务”里面,是不是启动了别的邮件服务器,已将110或25端口占用了。
  实例:
  james前台直接运行时出错:
repository文件夹可以删除吗  ERROR 2005-08-25 08:58:38.642 [
  Phoenix.] (): Compo
nent named "smtpserver" failed to pass through the Initialization stage. (Reason: java.BindException: Address already in use: JVM_Bind).
  ERROR 2005-08-25 08:58:38.652 [
  Phoenix.] (): There was an error running phase "startup" for Block named "smtpserver". (Reason: Component named "smtpserver" failed to pass through the Initialization stage. (Reason: java.BindException: Address already in use: JVM_Bind).).
  ainerkit.lifecycle.LifecycleException: Component named "smtpserver" failed to pass through the Initialization stage. (Reason: java.BindException: Address already in use: JVM_Bind).
  原因:
  james默认设置不允许在同一台机器上跑两个邮件服务器进程。必须关掉另一个!
  检测方法:
  console界面下:
  d:> telnet 主机名 25(或110)
  如果可以登录,出现
  220 主机名 Microsoft ESMTP MAIL Service, Version: 6.0.2600.1106 ready at Thu,
  25 Aug 2005 14:14:36 +0800
  则说明此机器上已有一台邮件服务器在运行。
  解决:
  检查Windows上运行服务:
  跨网传输的服务Simple Mail Transfer Protocol (SMTP),是否启动
  如启动关闭之!
  2、 JAVA_HOME不到?
  请在run.bat中指定JAVA_HOME,若还不行,请在“我的电脑—>系统—>高级—>环境变量”中添加一项JAVA_HOME。
  3、 服务器启动正常,但客户端不能收发邮件?
  请检查客户端配置是否正常,参照前面所讲,另外,请检查james下的l,是否把localhost改成了机器名。
  4、修改为数据库储存后,james启动出错:
  一般是数据库驱动有错。检查一下
  <data-source name="maildb" class="org.apache.dred.JdbcDataSource">
  <driver>sql.Driver</driver>
  <dburl>jdbc:mysql://127.0.0.1/mail</dburl>
  <user>root</user>
  <password></password>
  <max>20</max>
  </data-source>
  的<driver>sql.Driver</driver>是否对;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。