9 Configuring Operational and Global Settings
This chapter includes the following sections:
Introduction to Operational Settings
You can also manage business services by specifying how to handle offline endpoint URIs, limiting the message flow, and enabling result caching. Global operational settings override service-level settings.
Available Operational Settings
Operational settings let you configure things like monitoring, alerts, reporting, logging, message tracing, and business service result caching. You can specify operational settings for all services, at the service and global level, and use the global settings to turn on and off monitoring, SLA alerts, pipeline message reporting, and pipeline message logging. The available settings are described in the following sections.
State
This operational setting enables or disables a service. By default, the state of all services is enabled.
Monitoring
This operational setting enables or disables service monitoring. For pipelines and split-joins, you can also configure the level at which monitoring is performed. Certain other operational settings, such as logging and alerts, rely on monitoring being enabled. By default, monitoring is disabled for all services.
For pipelines, monitoring can be enabled at the following levels.
-
Action (A)
-
Pipeline (P)
-
Service (S)
For split-joins, monitoring can be enabled at the following levels.
-
Activity (A)
-
Branch (B)
-
Service (S)
You configure the level on the pipeline or split-join Properties page, and the level indicator is displayed on the Service Bus and Service Bus Project Operations pages.
Aggregation Interval
This operational setting defines the aggregation interval for the service in hours and minutes. The aggregation interval is the time period over which statistical data is collected and displayed. The default interval is 10 minutes.
Service-Level Agreement Alerts
This operational setting enables service-level agreement (SLA) alerting for services at a specific severity level or above. You can also use this to disable SLA alerting for a service. By default, SLA alerting is enabled for all services.
SLA alerting can be enabled at the following levels. You configure the alerting level on the service's Properties page, and the level indicator is displayed on the Service Bus and Service Bus Project Operations pages.
-
Normal (N)
-
Warning (W)
-
Minor (Mn)
-
Major (Mj)
-
Critical (C)
-
Fatal (F)
Pipeline Alerts
This operational setting enables alerting for pipelines at a specific severity level or above. You can also use this to disable pipeline alerting. By default, pipeline alerts are enabled at the Normal level or higher. For more information about monitoring pipeline alerts, see Monitoring Oracle Service Bus Alerts. For information about configuring alerts, see Reporting Actions and Adding Alert Actions in Developing Services with Oracle Service Bus.
Pipeline alerting can be enabled at the following levels. You configure the level on the pipeline's Properties page, and the level indicator is displayed on the Service Bus and Service Bus Project Operations pages.
-
Normal (N)
-
Warning (W)
-
Minor (Mn)
-
Major (Mj)
-
Critical (C)
-
Fatal (F)
Reporting
This operational setting enables or disables message reporting for pipelines. In Service Bus, message data can be captured from the message body and other message variables. This data is then delivered to one or more reporting providers. Information about SLA violations is also included in the reporting data. By default, reporting is enabled at the Normal level or higher.
Logging
This operational setting enables logging at a specific severity level or above for pipelines and split-joins. The severity level of the log actions in the pipeline or split-join must match the Logging severity level on that pipeline's or split-join's operational settings. By default, logging is enabled at the Debug level or higher.
Logging can be enabled at the following levels. You configure the level on the Properties page for the pipeline or split-join, and the level indicator is displayed on the Service Bus and Service Bus Project Operations pages.
-
Debug (D)
-
Info (I)
-
Warning (W)
-
Error (E)
To see log data in the log file or standard out (server console), Oracle WebLogic Server logging must be set to specific severity levels. For more information, see Configuring Message Tracing for a Service.
Execution Tracing
This operational settings enables or disables execution tracing for pipelines and split-joins. Service Bus lets you trace messages without having to shut down the server, making it easier to troubleshoot and diagnose a message flow. By default, execution tracing is disabled. After you enable execution tracing, the system logs various details culled from the pipeline context and the message context. These details include: stage name; pipeline or route node name; and the current message context.
For tracing to appear in the log file or standard out (server console), Oracle WebLogic Server logging must be set to the Info severity level. For more information about execution tracing, see Using Execution Tracing to Diagnose Problems.
Message Tracing
This operational setting enables or disables message tracing for services at a specific detail level or above. You can also set the payload limit (in kilobytes) and the default encoding. By default, message tracing is disabled.
For tracing to appear in the log file or standard out (server console), Oracle WebLogic Server logging must be set to the Info severity level. For instructions on configuring message tracing, see Configuring Message Tracing for a Service. Additionally, you must provide the default encoding of the payload. For example, if the payload is in Shift_JIS encoding, specify that in the Default Encoding field to ensure that those bytes are converted to UTF8 in the log file.
Offline Endpoint URIs
This operational setting enables or disables non-responsive endpoints for business services. When you select this option, the business service removes non-responsive endpoint URIs (takes them offline), at runtime, so that only the responsive URIs are used for retry attempts and for processing subsequent requests.
You can specify the interval of time to wait before retrying the offline endpoint URI. You can enable or disable offline URIs for business services only. By default, offline endpoint URIs are disabled.
For more information about offline endpoint URIs, see Monitoring and Managing Endpoint URIs for Business Services For instructions on marking endpoint URIs offline, see Configuring Service Bus to Take Unresponsive Endpoint URIs Offline.
Throttling Settings
You can restrict the flow of messages through a business service by enabling throttling for the service and configuring concurrency, the throttling queue, and a time to live (TTL) for queued messages. Throttling properties include the following:
-
Throttling State: This operational setting enables or disables throttling for a business service. By default, throttling is disabled.
-
Maximum Concurrency: This operational setting restricts the number of messages that can be concurrently processed by a business service. The default number of messages is 0 (zero), indicating no limit.
-
Throttling Queue: This operational setting restricts the maximum number of messages in the throttling queue. The default number of messages is 0 (zero), which implies that there is no queue.
-
Message Expiration: The maximum time interval (in milliseconds) for which a message can be placed in throttling queue. The default number of messages is 0 (zero), indicating no limit.
For more information about throttling business services, see Configuring Business Services for Message Throttling.
Result Caching State
This operational setting enables or disables result caching for a business service. By default, result caching is enabled globally. For more information about result caching, see "Improving Performance by Caching Business Service Results" in Developing Services with Oracle Service Bus.
Automatic Service Migration
Automatic Service Migration (ASM) leverages the WebLogic service migration framework to migrate services from servers that are down due to failure or maintenance to other available servers in the cluster.
Note:
This SOA Suite feature is part of Oracle Integration Continuous Availability. Please refer to Oracle SOA Suite for Oracle Middleware Options in the Oracle Fusion Middleware Licensing Information User Manual for more details on Oracle SOA Suite for Middleware Options.
Service Bus supports ASM for the following:
-
Singleton services, such as the Aggregator and the SLA Alert Manager
-
The File, FTP, SFTP, and Email poller transports. These transports are cluster singleton services that run on only one managed server in a cluster.
Note:
ASM is only available for clustered domains. It has no effect in single-node domains.
See Prerequisites to Enabling Automatic Service Migration for prerequisites to enabling ASM. Refer to Configuring Operational Settings at the Global Level to enable ASM.
When the ASM option is enabled, Service Bus deploys an app-scoped singleton service for the Aggregator service and each poller proxy service with a target of the preferred managed server first and the cluster second. Both the Aggregator service and the poller proxy services are eligible for migration to any server in a cluster; there are no sub-sets of servers in the cluster for service migration. A service’s polling will start on the preferred managed server initially. When the preferred managed server goes down, the services target managed servers available in the cluster sequentially. Even if the preferred managed server comes up in between, polling may not start on that server. All servers must be restarted after enabling ASM before processing messages.
Tip:
It is best practice to ensure that all managed servers are not running before enabling ASM. This avoids any ambiguous situations for message processing, particularly for poller transports.
After the ASM option is selected and the managed servers are restarted, performing these actions on poller proxy services in the Service Bus console has the following results:
-
Create: A new app-scoped singleton service is created for the new service.
-
Update/Rename/Move: A new app-scoped singleton service is created for that service and; the old singleton is undeployed and its files are deleted.
-
Delete: The singleton for that service is undeployed and its files are deleted.
-
Clone: A new app-scoped singleton service is created for the cloned service; the singleton for original service still exists.
-
Undo: Undoes the most recent change.
When the ASM option is disabled (after previously being enabled), Service Bus undeploys the singleton services that were created for the poller transports and deletes all files associated with them. All servers must be restarted after disabling ASM before these changes take effect.
ASM does not affect synchronous services, such as EJB, JEJB, and HTTP services. In these cases, the client receives and exception during invocation if the service is not available; the client must send the request again or the retry option must be configured, if available.
See Service Migration in Administering Clusters for Oracle WebLogic Server for additional information about the WebLogic Server service migration framework.
Prerequisites to Enabling Automatic Service Migration
Before enabling Automatic Service Migration in Enterprise Manager, update the Migration Basis for services and configure the alert store to use a WLDF JDBC-based store.
What You Need to Know About Domain Behavior in ASM and Dynamic Clusters
This topic lists the different behaviors of the domain depending on whether the environment is clustered with or without ASM.
During domain creation in the Configuration Wizard:
-
ASM is selected and No Dynamic cluster chosen: The Enterprise Manager flag for OSB Singleton migration (OSB Singleton Components Automatic Migration) is automatically enabled in the Global Settings Page. The Aggregator Marker Application will be deployed to the cluster.
-
ASM is not selected and Dynamic cluster chosen with configured managed server: The Enterprise Manager flag for OSB Singleton migration (OSB Singleton Components Automatic Migration) is automatically enabled in the Global Settings Page. The Aggregator Marker Application will be deployed to the cluster.
-
ASM is selected and Dynamic cluster chosen with configured managed server: The Enterprise Manager flag for OSB Singleton migration (OSB Singleton Components Automatic Migration) is automatically enabled in the Global Settings Page. The Aggregator Marker Application will be deployed to the cluster.
-
ASM is not selected and No Dynamic cluster chosen: The Enterprise Manager flag for OSB Singleton migration (OSB Singleton Components Automatic Migration) is automatically disabled in the Global Settings Page. The Domain Marker Application will be deployed with target as one of the configured managed servers of the cluster.
-
ASM is not selected and Dynamic cluster chosen without configured managed server: The Enterprise Manager flag for OSB Singleton migration (OSB Singleton Components Automatic Migration) is automatically enabled in the Global Settings Page. In this case, the flag should not be changed from the Enterprise Manager. If it is changed, an exception will be raised in the server log and the flag is not updated.
Except for the last scenario, the OSB Singleton migration flag (OSB Singleton Components Automatic Migration) can be enabled and disabled from the Global Settings Page of the Enterprise Manager for OSB. If it is enabled, the Aggregator Marker Application is deployed to the cluster. If it is disabled, the Domain Marker Application is deployed to one of the configured managed servers of the cluster.
Comment Logging
Select this option to display a comment (description) in the <server_name>-diagnostic.log
file in case of an error during pipeline execution. If this option is not selected, only the fixed node name appears in the log. The default value is false.
Note:
If you change the value of this parameter, the server must be restarted for the changes to take effect at runtime.
JavaScript Timeout
The JavaScript timeout is a value defining the time interval after which any JavaScript execution will be aborted with an error. The default value is 30 seconds.
Resequencer Settings
For services that use the resequencer to put messages in sequence, you can configure the resequencer settings, including the length of time the locker thread waits when it is unable to find a group with messages to process and the maximum number of resequencer groups to retrieve at one time. You can also configure the resequencer to purge messages that have been processed from the resequencer database.
Global and Service-Level Operational Settings
The runtime effects of the service-level settings depend on their corresponding global settings. You must enable both the global and service-level settings for a service to be completely enabled at runtime. The service state must also be enabled. You can change and save monitoring configuration settings even if the service will be not be enabled at runtime. For example, you can change and save the aggregation interval even if service monitoring is disabled. In this manner, you can edit settings and later enable them.
When you enable or disable monitoring at the global level, it enables or disables monitoring for all services that have individually been enabled for monitoring. If monitoring for a particular service has not been enabled, you must first enable it and set the aggregation interval for that specific service before the system starts collecting statistics for that service.
Enable or disable these settings at the global level in conjunction with the settings at the service level to effectively enable or disable them. The operational settings at the global level supersede the operational settings at the service level. The following settings must be enabled at the global level in order to be enabled for a specific service:
-
Monitoring
-
SLA Alerting
-
Pipeline Alerting
-
Reporting
-
Logging
-
Result Caching
-
Automatic Service Migration
-
JavaScript Timeout
-
Comment Logging Enabled
Viewing and Configuring Operational Settings
Use the Operations pages to easily locate proxy services, business services, pipelines, and split-joins, and to specify service-specific operational settings.
On the Service Bus or Service Bus Project Operation pages, you can set the aggregation interval, enable settings, and disable settings for multiple services. You can configure operational settings for a single service on that service's Properties page. When you update operational settings from the Service Bus or Service Bus Project Operations pages, you cannot specify an alerting or logging severity level, configure message tracing properties, or configure throttling or endpoint URIs for business services.
Keep in mind the following guidelines when configuring operational settings:
-
In general, properties must be enabled at both the service level and the global level in order to take effect.
-
Although you can configure SLA Alerts independently from Monitoring, there is an interaction between the two settings at runtime. If global monitoring is enabled, SLA alerts can be enabled or disabled. However, if global monitoring is disabled then SLA alerts are also effectively disabled because SLA alert rule conditions depend on monitoring statistics being evaluated.
-
If you disable monitoring for all services, all statistics collected so far for those services are deleted as well and the deletion of the statistics is irreversible.
Some operational settings such as service state, monitoring, SLA alerting, and pipeline alerting can also be enabled or disabled using public APIs. For more information, see Java API Reference for Oracle Service Bus.
Configuring Operational Settings at the Global Level
When you configure an operational setting at the global level (also called global settings), it affects all applicable services in the domain. Most settings must be enabled at both the service and global levels in order to take effect at runtime. Use the Global Settings tab of the Service Bus home page to update settings at the global level.
To configure operational settings at the global level:
Operational Settings at the Global Level
The following table describes operational settings at the global level.
Table 9-1 Operational Settings at the Global Level
Operational Setting | Usage |
---|---|
Monitoring Enabled |
Select this check box to enable monitoring for all services at the domain level. When this is enabled, the system collects monitoring statistics for all services whose monitoring is enabled at the service level. Clear this check box to disable monitoring for all services at the domain level.This not only overrides the operational monitoring setting, but also the operational SLA alerts setting. If you disable monitoring at the global level, SLA alerts are also disabled, even though the SLA Alerts check box is selected for certain services. Note: If you disable monitoring for all services, all statistics collected so far for those services are deleted as well. These statistics cannot be restored; the deletion of the statistics is irreversible. |
SLA Alerting Enabled |
Select this check box to enable SLA alerts for all services at the domain level. When SLA alerting is enabled, the system starts evaluating alert rules for all services in the domain. Clear this check box to disable SLA alerts for all services at the domain level. When SLA alerting is disabled, the system stops evaluation alert rules for all services in the domain. Although you can configure SLA Alerts independently from Monitoring, there is an interaction between the two settings at run time. If global monitoring is enabled, SLA alerts can be enabled or disabled. However, if global monitoring is disabled then SLA alerts will be effectively disabled because SLA alert rule conditions depend on monitoring statistics being evaluated. |
Pipeline Alerting Enabled |
Select this check box to enable pipeline alerting for all pipelines at the domain level. When pipeline alerting is enabled, the system executes any pipeline alert actions for proxy services. Clear this check box to disable pipeline alerting for all pipelines at the domain level. When pipeline alerting is disabled, the system no longer executes any pipeline alert actions. |
Reporting Enabled |
Select this check box to enable pipeline report actions at the domain level and start any pipeline report actions. This option controls pipeline report actions on the message context only. It does not effect SLA alerts or pipeline alerts targeted to the reporting framework. Clear this option to disable pipeline report actions at the domain level and stop any report actions for all proxy services. |
Logging Enabled |
Select this check box to enable pipeline and split-join log actions at the domain level. When this is enabled, pipeline and split-join Log action messages are sent to the WebLogic Server logging service. To view the messages, you must configure WebLogic Server to forward these messages to the domain log. Clear this check box to disable pipeline and split-join log actions at the domain level. This stops any Log actions for all pipelines and split-joins. |
Result Caching Enabled |
Select this check box to enable result caching for business services at the domain level. If you invoke business services whose results seldom change, result caching improves business service performance by returning cached results to the client instead of waiting for the results of a service invocation. Clear this check box to disable result caching for business services at the domain level. When you disable result caching globally, Service Bus flushes the entire cache, removing cached results for all business services with result caching enabled. |
OSB Singleton Components Automatic Migration |
Select this check box to enable Automatic Service Migration (ASM). When selected, Service Bus creates and deploys an app-scoped singleton service as an EAR, one for each poller proxy service and the aggregator service, targeted to the preferred managed server and cluster. When the preferred managed server goes down, the poller will target any available server in the cluster sequentially. All servers must be restarted after enabling ASM. Clear this check box and apply the change to undeploy and delete all app-scoped singleton services. All servers must be restarted for this change to take effect. |
Email Header Trim Enabled |
Select this option to enable Service Bus to trim the message header in email business transport if it has more than 998 characters. |
Comment Logging Enabled |
Select this option to display a comment (description) in the Note: If you change the value of this parameter, the server must be restarted for the changes to take effect at runtime. |
JavaScript Timeout |
Specify the time interval (in seconds) after which any JavaScript execution terminates with an error. The default value is 30 seconds. |
Resequencer Locker Thread Sleep |
Specify the sleep interval for the locker threads in seconds. When the resequencer is unable to find a group with messages that can be processed, the locker thread sleeps for the specified duration. The locker thread does not sleep between each iteration of a database seek, as long as it finds groups with messages that can be processed. The default value is 10 seconds. |
Resequencer Maximum Groups Locked |
Specify the maximum number of groups that can be retrieved for processing in a single iteration of a database seek. Once retrieved, the groups are assigned to worker threads for processing. The default value is 5. |
Purge Completed Messages |
Select this option to purge resequenced messages that have completed processing from the resequencer database. This option is selected by default. Note: When this option is selected completed messages cannot be viewed on the Resequence Messages tab. |
Searching for Services to Configure Their Operational Settings
Fusion Middleware Control provides several options for configuring operational settings, but all begin with performing a search for the services you want to configure.
Note:
The following steps describe how to view and update operational settings for multiple services. You can also view and update settings for a single service on that service's Properties page.
To search for services to configure their operational settings:
Enabling and Disabling Operational Settings for Multiple Services
The settings you can configure for a service vary depending on whether you are configuring a business service, proxy service, pipeline, or split-join. When you configure settings for multiple services, you do so on the Operations tab of the Service Bus or Service Bus Project page. The Operations list on these pages only includes enabling and disabling operational settings. Any settings that require specific configuration, like throttling or offline endpoint URI management, can only be configured on a specific service's Properties page.
For information about configuring specific operational settings, see Available Operational Settings and the online help provided with Service Bus.
To configure operational settings for multiple services:
Enabling and Disabling Operational Settings for a Single Service
In addition to enabling and disabling operational settings from the Operations page of the Service Bus or Service Bus Project page, you can also enable and disable settings for a service from its Properties page. For most services, you can also configure the operational settings in more detail, such as setting logging and monitoring levels.
For information about configuring specific operational settings, see Available Operational Settings and the online help provided with Service Bus. The following figure shows the Properties page for a service.
To enable or disable operational settings for a single service:
Setting the Aggregation Interval for a Service
Use a service's Properties page to set the aggregation interval for that service. The aggregation interval is the period over which aggregated statistics are computed for display in Fusion Middleware Control. The default aggregation interval setting is 10 minutes.
To set the aggregation interval for a service:
Configuring the Monitoring Level for a Pipeline or Split-Join
For pipelines and split-joins, you can specify the level at which the services are monitored. For more information, see Monitoring and the online help provided with Service Bus.
To configure the monitoring level for a service:
Configuring Message Tracing for a Service
After you enable message tracing for a proxy service, the system logs messages exchanged between the pipeline and the proxy service, including inbound request and response as well as outbound request and response messages. After you enable message tracing for a business service, the system logs messages exchanged between the pipeline and the business service (outbound request and response messages).
When applicable, logged outbound messages can also include the retry number, error code, and error message. In order for the tracing information to be logged to the server log file or server console, you must also configure the severity level for Oracle WebLogic Server logging.
To set Oracle WebLogic Server log levels:
To see tracing in the log file or standard out (server console), Oracle WebLogic Server logging must be set to the following severity levels:
-
Minimum severity to log: Info
-
Log file: Info
-
Standard out: Info
For information on setting log severity levels, see "Using Log Severity Levels" in Configuring Log Files and Filtering Log Messages for Oracle WebLogic Server.
To enable message tracing for a service:
Configuring the SLA Alert Level for a Service
You can configure the alert level for SLA alerts for a service. For more information, see Service-Level Agreement Alerts and the online help provided with Service Bus.
To configure the SLA alerting level for a service:
Configuring the Pipeline Alert Level
You can configure the alert level for pipeline alerting for a service. For more information, see Pipeline Alerts and the online help provided with Service Bus.
To configure the pipeline alerting level for a service:
Configuring the Logging Level for a Service
You can configure the logging level for pipelines and split-joins. For more information, see Logging and the online help provided with Service Bus.
To configure the logging level for a service:
Configuring Throttling for a Business Service
Business service throttling is described in Configuring Business Services for Message Throttling. For information and instructions on configuring throttling, see Configuring Throttling for a Single Business Service.
Configuring Offline Endpoint URI Handling for a Business Service
Managing offline endpoint URIs is described in Monitoring and Managing Endpoint URIs for Business Services. For information and instructions on configuring endpoint URI handling, see Configuring Service Bus to Take Unresponsive Endpoint URIs Offline.
Making Bulk Updates to Operational Settings
Service Bus lets you create configuration files that you can use to update certain environment values that are likely to change when you move a project from one domain to another, such as moving from a development to a testing environment.
This includes updating operational settings at both the global and service levels. For information about creating and executing configuration files, see Configuring Service Bus to Take Unresponsive Endpoint URIs Offline.
Preserving Operational Settings During Resource Imports
When you import Service Bus configuration JAR files in Oracle JDeveloper, the Oracle Service Bus Console, or Fusion Middleware Control, the domain-level settings can be overwritten if the configuration being imported also contains the global settings of the domain from which it is being imported.
Select the Preserve Operational Settings flag when importing the service to retain the global settings in the configuration being imported. This overwrites the global settings of the existing system. The same applies for the operational settings for individual services when the service is updated by an import process.
You can also preserve operational settings when importing Service Bus configurations using APIs. For more information, see the ALSBConfigurationMBean
documentation in the Java API Reference for Oracle Service Bus. Modify the MBean as shown in the following example to preserve the settings during the import.
Example - Preserve Operational Settings During the Import of Oracle Service Bus Configurations Through APIs
/** // Imports a configuration jar file, applies customization, activates it and exports the resources again // @throws Exception / static private void simpleImportExport(String importFileName, String passphrase) throws Exception { SessionManagementMBean sm = ... // obtain the mbean to create a session; // obtain the raw bytes that make up the configuration jar file File importFile = new File(importFileName); byte[] bytes = readBytes(importFile); // create a session String sessionName = "session." + System.currentTimeMillis(); sm.createSession(sessionName); // obtain the ALSBConfigurationMBean that operates on the // session that has just been created ALSBConfigurationMBean alsbSession = getConfigMBean(sessionName); // import configuration into the session. First we upload the // jar file, which will stage it temporarily. alsbSession.uploadJarFile(bytes); // then get the default import plan and modify the plan if required ALSBJarInfo jarInfo = getImportJarInf(); ALSBImportPlan importPlan = jarInfo.getDefaultImportPlan(); // preserve operational values importPlan. setPreserveExistingOperationalValues(true); // Modify the plan if required and pass it to importUploaeded method ImportResult result = alsbSession.importUploaded(importPlan); // Pass null to importUploaded method to mean the default import plan. //ImportResult result = alsbSession.importUploaded(null); // print out status if (result.getImported().size() > 0) { System.out.println("The following resources have been successfully imported."); for (Ref ref : result.getImported()) { System.out.println("\t" + ref); } } if (result.getFailed().size() > 0) { System.out.println("The following resources have failed to be imported."); for (Map.Entry e : result.getFailed().entrySet()) { Ref ref = e.getKey(); // Diagnostics object contains validation errors // that caused the failure to import this resource Diagnostics d = e.getValue(); System.out.println("\t" + ref + ". reason: " + d); } // discard the changes to the session and exit System.out.println("Discarding the session."); sm.discardSession(sessionName); System.exit(1); } // peform the customization to assign/replace environment values and // to modify the references. ... // activate the session sm.activateSession(sessionName, "description"); // export information from the core data ALSBConfigurationMBean alsbcore = getConfigMBean(null); //export the information at project level, pass only a collection of project refs to this method byte[] contentsProj = alsbcore.exportProjects(Collections.singleton(Ref.DEFAULT_PROJECT_REF),null); // the byte contents can be saved as jar file }