Hyperic 4.5 釋出

工程 | Jennifer Hickey | 2010 年 11 月 10 日 | ...

經過幾個月的發展,我很榮幸地宣佈 Hyperic 4.5 的釋出。 在此版本中,我們將 Hyperic 從在 JBoss 上執行的 EJB 應用程式遷移到在 Tomcat 上執行的 Spring Web 應用程式。 詳細的遷移步驟在我的 將 Hyperic 從 EJB 遷移到 Spring 的案例研究 中有介紹,最初是在最近的 SpringOne 2GX 上提出的。 在這篇文章中,我想重點介紹一下我最喜歡的關於轉換的一些事情。

改進的可測試性

切換到 Spring 使我們能夠將現有的 Stateless Session EJB 轉換為具有自動裝配依賴項的 POJO。 這消除了大量的靜態 JNDI 查詢程式碼,這使得單元測試非常困難。 Spring 還使整合測試變得更加容易。 在轉換之前,我們有一些整合測試,每個測試都需要幾分鐘來引導 EJB 容器的近似值。 這個過程很麻煩而且容易出錯。 此外,測試通常會使資料庫處於不一致的狀態,因此有必要新增資料庫設定或清理程式碼,從而增加測試執行時間的額外開銷,並且偶爾會導致不一致的測試結果。

轉換後,我們能夠利用 Spring 的整合測試支援來測試我們新的服務層(轉換後的 EJB)及其底層 DAO。 透過簡單地新增一些註釋,我們能夠在不到 30 秒的時間內引導整個應用程式上下文,並在一個專用事務中執行每個測試方法,該事務在測試結束時自動回滾。 事實證明,此支援對於讓我們快速將開源和企業程式碼庫中的測試覆蓋率分別提高 18% 和 12% 非常有價值。


@Transactional
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath*:META-INF/spring/*-context.xml")
public class AppdefManagerTest  {

  @Autowired
  private AppdefManager appdefManager;

  @Before
  public void setUp() throws Exception {
      createPlatformType("TestPlatform", "test");
  }

  @Test
  public void testGetControllablePlatformTypes() throws Exception {
      Map<String, AppdefEntityID> platformTypes = appdefManager
          .getControllablePlatformTypes(subject);
      assertEquals(1, platformTypes.size());
      assertEquals("TestPlatform", platformTypes.keySet().iterator().next());
  }
}

降低程式碼複雜性

簡單地引入 Spring 進行依賴注入,透過消除冗長的依賴查詢,大大簡化了許多區域中的程式碼。 但是,在許多其他地方,Spring 的引入顯著提高了程式碼的清晰度,減少了基礎結構的混亂,並使我們能夠專注於真正的業務邏輯。 在 Hyperic 中,我最喜歡的兩個例子是使用 JmsTemplate 釋出 JMS 訊息和使用 JdbcTemplate 進行資料訪問。

訊息釋出之前


public void publishMessage(String name, Serializable sObj) {
       TopicConnection conn = null;
       TopicSession session = null;
       if (_ic == null)
               _ic = new InitialContext();
            if (_factory == null)
               _factory = _ic.lookup(CONN_FACTORY_JNDI);
            TopicConnectionFactory tFactory = (TopicConnectionFactory) _factory;
            Topic topic = getTopic(name);
            if (topic != null) {
               // Now create a connection to send a message
               if (_tConn != null)
                   conn = _tConn;
               else
                   conn = tFactory.createTopicConnection();
               if (conn == null)
                   _log.error("TopicConnection cannot be created");
               if (_tSession != null)
                   session = _tSession;
               else
                   session = conn.createTopicSession(false,
                                                     Session.AUTO_ACKNOWLEDGE);
               // Create a publisher and publish the message
               TopicPublisher publisher = session.createPublisher(topic);
               ObjectMessage msg = session.createObjectMessage();
               msg.setObject(sObj);
               publisher.publish(msg);
       ...
}

訊息釋出之後


public void publishMessage(String name, Serializable sObj) {
       eventsJmsTemplate.convertAndSend(name, sObj);
}

資料訪問之前


public int getServicesCount(AuthzSubject subject) {
       Statement stmt = null;
       ResultSet rs = null;
       Integer subjectId = subject.getId();
        try {
           Connection conn = getDBConn();
           String sql = "SELECT COUNT(SVC.ID) FROM TBL_SERVICE";
           stmt = conn.createStatement();
           rs = stmt.executeQuery(sql);
           if (rs.next()) {
               return rs.getInt(1);
           }
       } catch (SQLException e) {
           log.error("Caught SQL Exception finding Services by type: " + e, e);
                    throw new SystemException(e);
       } finally {
           DBUtil.closeJDBCObjects(LOG_CTX, null, stmt, rs);
       }
       return 0;
}

資料訪問之後


public int getServicesCount(AuthzSubject subject) {
       return jdbcTemplate.queryForInt("SELECT COUNT(SVC.ID) FROM TBL_SERVICE");
   }

這真是一個減肥計劃! 僅透過轉換為 Spring 而不更改任何功能,我們就將開源和企業程式碼庫都減少了約 7%。

提高開發者生產力

如上所述,Spring 對整合測試的支援使我們能夠在不到 30 秒的時間內引導整個應用程式上下文,以進行端到端整合測試。 在測試新功能或除錯問題時,這節省了大量時間。 當我們確實需要啟動整個 Web 應用程式時,切換到 Tomcat 透過顯著減少啟動時間提高了我們的生產力。 現在,一個編碼和除錯應用程式的開發人員每次啟動應用程式時大約可以節省 5 分鐘的等待時間。 考慮到開發人員可能每天重啟應用程式 12 次,這每天可以騰出一個小時來開發新功能! 此外,更簡潔的程式碼和改進的單元可測試性使查詢和修復問題變得更快更容易,而靈活的架構使新增新功能和增強功能變得更容易。

這些只是在此版本中切換到 Spring 和 Tomcat 提供的一些好處。 實在太多了,無法在一篇博文中列出!

此版本還包含對三個 VMware vFabric 平臺服務的監視和管理,包括 vFabric GemFire 6.5 分散式快取系統RabbitMQ 企業訊息傳遞系統 和本週釋出的新 vFabric tc Server 2.1 Java 執行時伺服器。 Hyperic 的先前版本中已存在對 vFabric tc Server 的支援; 但是,在 4.5 中,該外掛現在與 Hyperic 發行版捆綁在一起,不再是單獨下載。 請在以後的部落格文章中查詢有關監視 GemFire 和 RabbitMQ 的更多資訊。

在遷移的同時,我們還藉此機會將我們的程式碼儲存庫從 subversion 遷移到 git。 要從 git 程式碼儲存庫下載原始碼,請訪問 http://git.springsource.org/hq。 我們還將構建系統從 ant 切換到 maven。 現在可以從我們的 maven 儲存庫 http://maven.hyperic.org/release 下載開發自定義外掛或功能所需的所有 Hyperic 模組。

結論

我鼓勵您下載 Hyperic 4.5 和/或 檢視程式碼。 與往常一樣,非常感謝透過 論壇 提供的社群反饋。 我們期待建立在轉換為 Spring 所提供的這種易於擴充套件的架構之上。 敬請關注更多精彩的增強功能!

獲取 Spring 新聞通訊

透過 Spring 新聞通訊保持聯絡

訂閱

搶佔先機

VMware 提供培訓和認證,以加速您的進步。

瞭解更多

獲得支援

Tanzu Spring 在一個簡單的訂閱中提供對 OpenJDK™、Spring 和 Apache Tomcat® 的支援和二進位制檔案。

瞭解更多

即將到來的活動

檢視 Spring 社群中所有即將到來的活動。

檢視全部