javax.management.remote.rmi

计算机术语

描述 RMI 连接器是供 JMX Remote API 使用的一种连接器,后者使用 RMI 将客户端请求传输到远程 MBean 服务器。此包定义了 RMI 连接器的用户直接引用客户端和服务器方所需的类。

连接器地址形式
JNDI 形式
在 JNDI 形式 中,URL 指示查找连接器的 RMI stub 的位置。此 RMI stub 是一个类型为 RMIServer 的 Java 对象,它提供了对连接器服务器的远程访问。使用这种地址形式,可从包含在 URL 中的外部目录条目获取 RMI stub。外部目录是指可由 JNDI 识别的任何目录,通常是 RMI 注册表、LDAP 或 CORBA 命名服务 (COS Naming)。
编码形式
在编码形式 中,URL 直接包括了连接到连接器服务器所需的信息。使用 RMI/JRMP 时,编码形式是服务器对象的序列化 RMI stub,它采用 BASE64 编码,未嵌入换行。使用 RMI/IIOP 时,编码形式是服务器对象的 CORBA IOR。
使用
创建 RMI 连接器服务器
创建 RMI 连接器服务器的一般方法是为方法 JMXConnectorServerFactory.newJMXConnectorServer 提供一个 RMI 连接器地址。连接器服务器要连接到的 MBean 服务器可作为该方法的一个参数指定。或者,也可以将连接器服务器注册为该 MBean 服务器中的 MBean。
还可以通过构造 RMIConnectorServer 的实例(显式或使用 MBean 服务器的 createMBean 方法)来创建 RMI 连接器服务器。
选择 RMI 传输方式
在创建连接器服务器时,通过在 serviceURL 的 protocol 部分指定 rmi 或 iiop,您可以选择 RMI 传输方式(JRMP 或 IIOP)。通过实例化 RMIServerImpl 的一个适当的子类并将其提供给 RMIConnectorServer 构造方法,您还可以创建特殊的连接器服务器。
服务器生成的连接器地址
如果您指定的 serviceURL 包含空 URL 路径(在可选的主机和端口后),或者未指定 serviceURL,则连接器服务器将创建一个可供客户端连接使用的新 JMXServiceURL:
如果 serviceURL 如下所示:
service:jmx:rmi://host:port
则连接器服务器将生成一个 RMIJRMPServerImpl,且返回如下所示的 JMXServiceURL:
service:jmx:rmi://host:port/stub/XXXX
其中,XXXX 为所生成对象的 stub 的序列化形式,其编码采用 BASE64,不带换行。
如果 serviceURL 如下所示:
service:jmx:iiop://host:port
则连接器服务器将生成一个 RMIIIOPServerImpl ,且返回如下所示的 JMXServiceURL:
service:jmx:iiop://host:port/ior/IOR:XXXX
其中,IOR:XXXX 为所生成对象的互操作对象引用 (Interoperable Object Reference) 的标准 CORBA 编码。
如果没有 serviceURL,则必须有一个用户提供的 RMIServerImpl。如果在此对象上调用 toStub 方法返回 Stub 的实例,则连接器服务器将用上述的 iiop 形式生成 JMXServiceURL。否则,它将用 rmi 形式生成 JMXServiceURL。
用户提供的 serviceURL 中的 host 为可选项。如果有这一项,则将其复制到生成的 JMXServiceURL 中,但是其他方面会忽略此项。如果没有这一项,则生成的 JXMServiceURL 将包括本地主机名。
用户提供的 serviceURL 中的 port 也是一个可选项。如果有这一项,则同样将其复制到生成的 JMXServiceURL 中;否则,生成的 JMXServiceURL 不带端口。对于使用 rmi 协议的 serviceURL,如果有 port,则它指示生成的远程对象应在该端口上导出。它没有任何其他作用。
如果用户提供了 RMIServerImpl 而不是 JMXServiceURL,则生成的 JMXServiceURL 将在其 host 部分包含本地主机名并且不带 port。
基于目录条目的连接器地址
作为刚才介绍的生成地址的另外一种情况,创建连接器服务器时提供的 serviceURL 地址指定的是目录地址,其中可存储提供的或生成的 RMIServer stub。然后客户端和服务器都可以使用此目录地址。
这种情况下,serviceURL 具有如下两种形式之一:
service:jmx:rmi://host:port/jndi/jndi-name
service:jmx:iiop://host:port/jndi/jndi-name
其中 jndi-name 是一个可提供给 javax.naming.InitialContext.bind 的字符串。
同样,host 和 :port 均可忽略。
连接器服务器将基于协议(rmi 或 iiop),对于 rmi,还包括 port(如果有)生成 RMIServerImpl。连接器服务器启动后,它将从此对象使用其 toStub 方法派生一个 stub 并使用给定的 jndi-name 保存该对象。同样也要参考由 JNDI API 定义的属性。
例如,假设 JMXServiceURL 为:
service:jmx:rmi://ignoredhost/jndi/rmi://myhost/myname
则连接器服务器将生成 RMIJRMPServerImpl 并使用该 JNDI 名称保存其 stub
rmi://myhost/myname
它表示运行在主机 myhost 的默认端口上 RMI 注册表中的 myname 项。注意,RMI 注册表只允许从本地主机注册。因此在这种情况下,myhost 必须是运行连接器服务器的主机名
在此 JMXServiceURL 中,第一个 rmi: 指定 RMI 连接器,第二个 rmi: 指定 RMI 注册表。
另举一个例子,如果 JMXServiceURL 为:
service:jmx:iiop://ignoredhost/jndi/ldap://dirhost:9999/cn=this,ou=that
则该连接器服务器将生成 RMIIIOPServerImpl 并使用该 JNDI 名称保存其 stub
ldap://dirhost:9999/cn=this,ou=that
它表示 LDAP 目录中的 cn=this,ou=that 条目,该目录在运行主机 dirhost 的端口 9999 上。
如果 JMXServiceURL 为:
service:jmx:iiop://ignoredhost/jndi/cn=this,ou=that
则该连接器服务器将生成 RMIIIOPServerImpl 并使用该 JNDI 名称保存其 stub
cn=this,ou=that
要在这种情况下正常工作,JNDI API 必须经过适当配置,以提供有关要使用的目录的信息。
这些示例中,主机名 ignoredhost 未被连接器服务器或其客户端使用。可将其忽略,例如:
service:jmx:iiop:///jndi/cn=this,ou=that
但是,在连接器服务器运行的主机上使用主机名是一个不错的做法。这通常不同于目录主机的名称。
连接器服务器的属性
使用默认的 JRMP 传输方式时,可使用为 RMIConnectorServer 构造方法给定的 environment 中的 jmx.remote.rmi.client.socket.factory 和 jmx.remote.rmi.server.socket.factory 属性指定 RMI 套接字工厂。这些属性的值的类型必须分别为 RMIClientSocketFactory 和 RMIServerSocketFactory。这些工厂在创建与连接器关联的 RMI 对象时使用。
创建 RMI 连接器客户端
RMI 连接器客户端通常使用 JMXConnectorFactory 且具有协议 rmi 或 iiop 的 JMXServiceURL 进行构造。
如果 JMXServiceURL 由服务器生成,如上文中的“服务器生成的连接器地址”所述,则客户端将需要直接或间接地从服务器获取该值。通常情况下,服务器将 JMXServiceURL 存储在一个文件或查找服务中以便使用。
如果 JMXServiceURL 使用目录语法,如上文中的“基于目录条目的连接器地址”所述,则客户端可用刚刚介绍的方法获取该值,或者客户端和服务器可能都知道要使用的适当目录条目。例如,如果 Whatsit 代理的连接器服务器使用主机 myhost 上 RMI 注册表中的 whatsit-agent-connector 条目,则客户端和服务器都知道适当的 JMXServiceURL 为:
service:jmx:rmi:///jndi/rmi://myhost/whatsit-agent-connector
如果 RMI stub 的类型为 RMIServer,则可以使用 RMIConnector 的适当构造方法直接构造 RMI 连接。
为 RMI IIOP 连接器指定ORB
使用 IIOP 传输方式时,客户端和服务器可使用属性 java.naming.corba.orb 指定要使用的 ORB。连接器服务器连接到 ORB 的动作发生时间为 start,连接器客户端连接到 ORB 的动作发生时间为 connect。如果 java.naming.corba.orb 属性包含在环境 Map 中,则其值(一个 ORB)将用于连接 IIOP Stub。否则,将通过调用 org.omg.CORBA.ORB.init((String[])null,(Properties)null) 创建一个新的 org.omg.CORBA.ORB。位于同一 JVM 中的后续 RMI 连接器客户端或服务器可重用此 ORB,或者可用同样的方式创建另一个 ORB。
如果指定了 java.naming.corba.orb 属性但它并不指向一个 ORB,则将抛出 IllegalArgumentException。
当 IIOP 远程对象(Stub 或 Server)在被传入到 RMIConnector 和 RMIConnectorServer 之前通过手动创建和连接到 ORB 时,这里描述的机制将不适用。
另请参见
全国各地天气预报查询

上海市

  • 市辖区
  • 云南省

  • 临沧市
  • 云南省

  • 丽江市
  • 云南省

  • 保山市
  • 云南省

  • 大理白族自治州
  • 云南省

  • 德宏傣族景颇族自治州
  • 云南省

  • 怒江傈僳族自治州
  • 云南省

  • 文山壮族苗族自治州
  • 云南省

  • 昆明市
  • 云南省

  • 昭通市
  • 云南省

  • 普洱市
  • 云南省

  • 曲靖市
  • 云南省

  • 楚雄彝族自治州
  • 云南省

  • 玉溪市
  • 云南省

  • 红河哈尼族彝族自治州
  • 云南省

  • 西双版纳傣族自治州
  • 云南省

  • 迪庆藏族自治州
  • 内蒙古自治区

  • 乌兰察布市
  • 内蒙古自治区

  • 乌海市
  • 内蒙古自治区

  • 兴安盟
  • 内蒙古自治区

  • 包头市
  • 内蒙古自治区

  • 呼伦贝尔市
  • 内蒙古自治区

  • 呼和浩特市
  • 内蒙古自治区

  • 巴彦淖尔市
  • 内蒙古自治区

  • 赤峰市
  • 内蒙古自治区

  • 通辽市
  • 内蒙古自治区

  • 鄂尔多斯市
  • 内蒙古自治区

  • 锡林郭勒盟
  • 内蒙古自治区

  • 阿拉善盟
  • 北京市

  • 市辖区
  • 吉林省

  • 吉林市
  • 吉林省

  • 四平市
  • 吉林省

  • 延边朝鲜族自治州
  • 吉林省

  • 松原市
  • 吉林省

  • 白城市
  • 吉林省

  • 白山市
  • 吉林省

  • 辽源市
  • 吉林省

  • 通化市
  • 吉林省

  • 长春市
  • 四川省

  • 乐山市
  • 四川省

  • 内江市
  • 四川省

  • 凉山彝族自治州
  • 四川省

  • 南充市
  • 四川省

  • 宜宾市
  • 四川省

  • 巴中市
  • 四川省

  • 广元市
  • 四川省

  • 广安市
  • 四川省

  • 德阳市
  • 四川省

  • 成都市
  • 四川省

  • 攀枝花市
  • 四川省

  • 泸州市
  • 四川省

  • 甘孜藏族自治州
  • 四川省

  • 眉山市
  • 四川省

  • 绵阳市
  • 四川省

  • 自贡市
  • 四川省

  • 资阳市
  • 四川省

  • 达州市
  • 四川省

  • 遂宁市
  • 四川省

  • 阿坝藏族羌族自治州
  • 四川省

  • 雅安市
  • 天津市

  • 市辖区
  • 宁夏回族自治区

  • 中卫市
  • 宁夏回族自治区

  • 吴忠市
  • 宁夏回族自治区

  • 固原市
  • 宁夏回族自治区

  • 石嘴山市
  • 宁夏回族自治区

  • 银川市
  • 安徽省

  • 亳州市
  • 安徽省

  • 六安市
  • 安徽省

  • 合肥市
  • 安徽省

  • 安庆市
  • 安徽省

  • 宣城市
  • 安徽省

  • 宿州市
  • 安徽省

  • 池州市
  • 安徽省

  • 淮北市
  • 安徽省

  • 淮南市
  • 安徽省

  • 滁州市
  • 安徽省

  • 芜湖市
  • 安徽省

  • 蚌埠市
  • 安徽省

  • 铜陵市
  • 安徽省

  • 阜阳市
  • 安徽省

  • 马鞍山市
  • 安徽省

  • 黄山市
  • 山东省

  • 东营市
  • 山东省

  • 临沂市
  • 山东省

  • 威海市
  • 山东省

  • 德州市
  • 山东省

  • 日照市
  • 山东省

  • 枣庄市
  • 山东省

  • 泰安市
  • 山东省

  • 济南市
  • 山东省

  • 济宁市
  • 山东省

  • 淄博市
  • 山东省

  • 滨州市
  • 山东省

  • 潍坊市
  • 山东省

  • 烟台市
  • 山东省

  • 聊城市
  • 山东省

  • 菏泽市
  • 山东省

  • 青岛市
  • 山西省

  • 临汾市
  • 山西省

  • 吕梁市
  • 山西省

  • 大同市
  • 山西省

  • 太原市
  • 山西省

  • 忻州市
  • 山西省

  • 晋中市
  • 山西省

  • 晋城市
  • 山西省

  • 朔州市
  • 山西省

  • 运城市
  • 山西省

  • 长治市
  • 山西省

  • 阳泉市
  • 广东省

  • 东莞市
  • 广东省

  • 中山市
  • 广东省

  • 云浮市
  • 广东省

  • 佛山市
  • 广东省

  • 广州市
  • 广东省

  • 惠州市
  • 广东省

  • 揭阳市
  • 广东省

  • 梅州市
  • 广东省

  • 汕头市
  • 广东省

  • 汕尾市
  • 广东省

  • 江门市
  • 广东省

  • 河源市
  • 广东省

  • 深圳市
  • 广东省

  • 清远市
  • 广东省

  • 湛江市
  • 广东省

  • 潮州市
  • 广东省

  • 珠海市
  • 广东省

  • 肇庆市
  • 广东省

  • 茂名市
  • 广东省

  • 阳江市
  • 广东省

  • 韶关市
  • 广西壮族自治区

  • 北海市
  • 广西壮族自治区

  • 南宁市
  • 广西壮族自治区

  • 崇左市
  • 广西壮族自治区

  • 来宾市
  • 广西壮族自治区

  • 柳州市
  • 广西壮族自治区

  • 桂林市
  • 广西壮族自治区

  • 梧州市
  • 广西壮族自治区

  • 河池市
  • 广西壮族自治区

  • 玉林市
  • 广西壮族自治区

  • 百色市
  • 广西壮族自治区

  • 贵港市
  • 广西壮族自治区

  • 贺州市
  • 广西壮族自治区

  • 钦州市
  • 广西壮族自治区

  • 防城港市
  • 新疆维吾尔自治区

  • 乌鲁木齐市
  • 新疆维吾尔自治区

  • 伊犁哈萨克自治州
  • 新疆维吾尔自治区

  • 克孜勒苏柯尔克孜自治州
  • 新疆维吾尔自治区

  • 克拉玛依市
  • 新疆维吾尔自治区

  • 博尔塔拉蒙古自治州
  • 新疆维吾尔自治区

  • 吐鲁番市
  • 新疆维吾尔自治区

  • 和田地区
  • 新疆维吾尔自治区

  • 哈密市
  • 新疆维吾尔自治区

  • 喀什地区
  • 新疆维吾尔自治区

  • 塔城地区
  • 新疆维吾尔自治区

  • 巴音郭楞蒙古自治州
  • 新疆维吾尔自治区

  • 昌吉回族自治州
  • 新疆维吾尔自治区

  • 自治区直辖县级行政区划
  • 新疆维吾尔自治区

  • 阿克苏地区
  • 新疆维吾尔自治区

  • 阿勒泰地区
  • 江苏省

  • 南京市
  • 江苏省

  • 南通市
  • 江苏省

  • 宿迁市
  • 江苏省

  • 常州市
  • 江苏省

  • 徐州市
  • 江苏省

  • 扬州市
  • 江苏省

  • 无锡市
  • 江苏省

  • 泰州市
  • 江苏省

  • 淮安市
  • 江苏省

  • 盐城市
  • 江苏省

  • 苏州市
  • 江苏省

  • 连云港市
  • 江苏省

  • 镇江市
  • 江西省

  • 上饶市
  • 江西省

  • 九江市
  • 江西省

  • 南昌市
  • 江西省

  • 吉安市
  • 江西省

  • 宜春市
  • 江西省

  • 抚州市
  • 江西省

  • 新余市
  • 江西省

  • 景德镇市
  • 江西省

  • 萍乡市
  • 江西省

  • 赣州市
  • 江西省

  • 鹰潭市
  • 河北省

  • 保定市
  • 河北省

  • 唐山市
  • 河北省

  • 廊坊市
  • 河北省

  • 张家口市
  • 河北省

  • 承德市
  • 河北省

  • 沧州市
  • 河北省

  • 石家庄市
  • 河北省

  • 秦皇岛市
  • 河北省

  • 衡水市
  • 河北省

  • 邢台市
  • 河北省

  • 邯郸市
  • 河南省

  • 三门峡市
  • 河南省

  • 信阳市
  • 河南省

  • 南阳市
  • 河南省

  • 周口市
  • 河南省

  • 商丘市
  • 河南省

  • 安阳市
  • 河南省

  • 平顶山市
  • 河南省

  • 开封市
  • 河南省

  • 新乡市
  • 河南省

  • 洛阳市
  • 河南省

  • 漯河市
  • 河南省

  • 濮阳市
  • 河南省

  • 焦作市
  • 河南省

  • 省直辖县级行政区划
  • 河南省

  • 许昌市
  • 河南省

  • 郑州市
  • 河南省

  • 驻马店市
  • 河南省

  • 鹤壁市
  • 浙江省

  • 丽水市
  • 浙江省

  • 台州市
  • 浙江省

  • 嘉兴市
  • 浙江省

  • 宁波市
  • 浙江省

  • 杭州市
  • 浙江省

  • 温州市
  • 浙江省

  • 湖州市
  • 浙江省

  • 绍兴市
  • 浙江省

  • 舟山市
  • 浙江省

  • 衢州市
  • 浙江省

  • 金华市
  • 海南省

  • 三亚市
  • 海南省

  • 三沙市
  • 海南省

  • 儋州市
  • 海南省

  • 海口市
  • 海南省

  • 省直辖县级行政区划
  • 湖北省

  • 十堰市
  • 湖北省

  • 咸宁市
  • 湖北省

  • 孝感市
  • 湖北省

  • 宜昌市
  • 湖北省

  • 恩施土家族苗族自治州
  • 湖北省

  • 武汉市
  • 湖北省

  • 省直辖县级行政区划
  • 湖北省

  • 荆州市
  • 湖北省

  • 荆门市
  • 湖北省

  • 襄阳市
  • 湖北省

  • 鄂州市
  • 湖北省

  • 随州市
  • 湖北省

  • 黄冈市
  • 湖北省

  • 黄石市
  • 湖南省

  • 娄底市
  • 湖南省

  • 岳阳市
  • 湖南省

  • 常德市
  • 湖南省

  • 张家界市
  • 湖南省

  • 怀化市
  • 湖南省

  • 株洲市
  • 湖南省

  • 永州市
  • 湖南省

  • 湘潭市
  • 湖南省

  • 湘西土家族苗族自治州
  • 湖南省

  • 益阳市
  • 湖南省

  • 衡阳市
  • 湖南省

  • 邵阳市
  • 湖南省

  • 郴州市
  • 湖南省

  • 长沙市
  • 甘肃省

  • 临夏回族自治州
  • 甘肃省

  • 兰州市
  • 甘肃省

  • 嘉峪关市
  • 甘肃省

  • 天水市
  • 甘肃省

  • 定西市
  • 甘肃省

  • 平凉市
  • 甘肃省

  • 庆阳市
  • 甘肃省

  • 张掖市
  • 甘肃省

  • 武威市
  • 甘肃省

  • 甘南藏族自治州
  • 甘肃省

  • 白银市
  • 甘肃省

  • 酒泉市
  • 甘肃省

  • 金昌市
  • 甘肃省

  • 陇南市
  • 福建省

  • 三明市
  • 福建省

  • 南平市
  • 福建省

  • 厦门市
  • 福建省

  • 宁德市
  • 福建省

  • 泉州市
  • 福建省

  • 漳州市
  • 福建省

  • 福州市
  • 福建省

  • 莆田市
  • 福建省

  • 龙岩市
  • 西藏自治区

  • 山南市
  • 西藏自治区

  • 拉萨市
  • 西藏自治区

  • 日喀则市
  • 西藏自治区

  • 昌都市
  • 西藏自治区

  • 林芝市
  • 西藏自治区

  • 那曲市
  • 西藏自治区

  • 阿里地区
  • 贵州省

  • 六盘水市
  • 贵州省

  • 安顺市
  • 贵州省

  • 毕节市
  • 贵州省

  • 贵阳市
  • 贵州省

  • 遵义市
  • 贵州省

  • 铜仁市
  • 贵州省

  • 黔东南苗族侗族自治州
  • 贵州省

  • 黔南布依族苗族自治州
  • 贵州省

  • 黔西南布依族苗族自治州
  • 辽宁省

  • 丹东市
  • 辽宁省

  • 大连市
  • 辽宁省

  • 抚顺市
  • 辽宁省

  • 朝阳市
  • 辽宁省

  • 本溪市
  • 辽宁省

  • 沈阳市
  • 辽宁省

  • 盘锦市
  • 辽宁省

  • 营口市
  • 辽宁省

  • 葫芦岛市
  • 辽宁省

  • 辽阳市
  • 辽宁省

  • 铁岭市
  • 辽宁省

  • 锦州市
  • 辽宁省

  • 阜新市
  • 辽宁省

  • 鞍山市
  • 重庆市

  • 重庆市

  • 市辖区
  • 陕西省

  • 咸阳市
  • 陕西省

  • 商洛市
  • 陕西省

  • 安康市
  • 陕西省

  • 宝鸡市
  • 陕西省

  • 延安市
  • 陕西省

  • 榆林市
  • 陕西省

  • 汉中市
  • 陕西省

  • 渭南市
  • 陕西省

  • 西安市
  • 陕西省

  • 铜川市
  • 青海省

  • 果洛藏族自治州
  • 青海省

  • 海东市
  • 青海省

  • 海北藏族自治州
  • 青海省

  • 海南藏族自治州
  • 青海省

  • 海西蒙古族藏族自治州
  • 青海省

  • 玉树藏族自治州
  • 青海省

  • 西宁市
  • 青海省

  • 黄南藏族自治州
  • 黑龙江省

  • 七台河市
  • 黑龙江省

  • 伊春市
  • 黑龙江省

  • 佳木斯市
  • 黑龙江省

  • 双鸭山市
  • 黑龙江省

  • 哈尔滨市
  • 黑龙江省

  • 大兴安岭地区
  • 黑龙江省

  • 大庆市
  • 黑龙江省

  • 牡丹江市
  • 黑龙江省

  • 绥化市
  • 黑龙江省

  • 鸡西市
  • 黑龙江省

  • 鹤岗市
  • 黑龙江省

  • 黑河市
  • 黑龙江省

  • 齐齐哈尔市