Monday, September 26, 2011

WebSphere Portal Server: Virtual Portals Concept

Introduction

  • Virtual Portals are logical portals that share the same WebSphere Portal Server hardware and software installation.
  • All the Virtual Portals, including the default portal, run on and share the same JVM (Java Virtual Machine).
  • Each Virtual Portals will have its own unique URI.

Sample Portal Architecture using an Virtual Portal

Advantages of VP feature

  • Using the VP feature we can not only save costs by using the shared resources for multiple portals, but we also can enable a new portal application much faster as you don’t have to spend time installing and configuring new hardware and software for the new portal.

Portal resources that are scoped for virtual portals

  • WebSphere Portal has the following portal resources scoped internally for virtual portals:
    • Portal pages
    • Portlet instances
    • Portal Search Engine search services and search collections. This includes the search content sources.
  • Scoping of these resources is managed by internal portal mechanisms.
  • Scoped resources are only available for the virtual portal for which they are defined. They are well isolated from other virtual portals.
  • Scoped resources cannot be shared with other virtual portals. They are not visible or accessible outside of the virtual portal for which they have been created. This behavior cannot be changed by any portal access control settings.

The rules applied on Virtual Portal

  • Within each virtual portal you or a subadministrator can use Portal Access Control to grant individual users of that virtual portal specific access rights to the scoped portal resources. This works just like under a single portal installation.
  • An administrator can give access rights to users who are members of the user population of a virtual portal only on the scoped resources of that same virtual portal. This implies that, vice versa, you can give access rights on the resources of a virtual portal only to those users who are members of the user population of that virtual portal.
  • Users can only use these access rights when they access the specific virtual portal under which they have the access rights on the scoped resources. The same users cannot access the resources when logging in to a different virtual portal.

Portal resources that you can separate for virtual portals by using Portal Access Control

  • There are some portal resources that are not scoped internally for a particular virtual portal. These resources are shared among all virtual portals of the entire installation. However, as a master administrator you can yourself separate such portal resources for the virtual portals. To do this, use Portal Access Control and the access rights portlets to set up the appropriate access rights for users on the resources of each virtual portal as required.
  • You can separate the following portal resources by using Portal Access Control to give users of an individual virtual portal access right to the resources:
    • Portlets
    • Portlet applications
    • Web modules
    • URL mapping contexts
    • Users and groups.
  • You can separate these resources for individual virtual portals by using Portal Access Control. When you do this, apply special care. It can be of benefit to document the relationships between the users and the virtual portals.

Portal resources that cannot be separated for virtual portals

  • There are some types of portal resources that are not scoped to a particular virtual portal, and you cannot separate them yourself by using Portal Access Control. The following list shows portal resources that you cannot separate for virtual portals:
    • Themes and skins. If you do not want subadministrators to be able to manage themes and skins, restrict their access rights on them.
    • Vault segments and vault slots. To avoid security problems, use private credentials only. They can be used by only one specific user.
    • Supported clients and markups. The settings for these are configured in the corresponding portlets; therefore they apply to the entire portal installation.
    • Composite applications and templates. There is one common application and template catalog per installation. Users see the applications and templates to which they have access, regardless of virtual portal assignments. For more information about applications and templates refer to Composite applications.
    • Policies. Policy resources are not scoped to virtual portals. Users see the policy resources to which they have access, regardless of the virtual portal assignments.
  • Examples:
    • Themes and skins can be accessed by all subadministrators who have the access right to apply themes and skins to the pages that they can administer, regardless of which virtual portal the subadministrators are responsible for.
    • If a subadministrator imports a new template into one virtual portal, this template will appear in the application template library of all virtual portals.

Content of a virtual portal

  • When we create the virtual portal by using the Virtual Portal Manager portlet, the portlet invokes an XML configuration interface script that creates the initial content of the new virtual portal.
  • Content (wps.content.root). This includes the following pages and portlets:
    • Home (ibm.portal.Home). This includes the Welcome page.
  • Welcome (ibm.portal.WebSphere Portal.Welcome). This includes the following portlet:
    • Page Customizer (ibm.portal.Page Customizer)
    • Page Properties (ibm.portal.Page Properties)
  • Welcome (wps.p.Welcome)
    • Organize Favorites (wps.p.Favorites)
  • Login (wps.Login). This contains the following portlet:
    • Login (wps.p.login)
  • Search (wps.p.Search Center)
  • Profile Management (wps.p.Selfcare)
  • Documents (wps.Documents). This contains the following portlet:
    • Document Manager (wps.p.Documents) and Document Picker (wps.p.DocPicker)
  • Administration (ibm.portal.Administration). This includes the following portlets:
    • Manage Pages (wps.p.Manage Pages)
    • Users and Groups (wps.p.Manage Users and Groups)
    • Resource Permissions (wps.p.Resource View)
    • User and Group Permissions (wps.p.User Group Permissions)
    • URL Mapping (wps.p.Url Mapping)
    • Custom Unique names (wps.p.Unique Names)
    • Manage Search (wps.p.Manage Search Admin)
    • Manage Document Libraries (wps.p.MDL)
    • Enable tracing (wps.p.Enable Tracing)
    • Portlet Palette (wps.p.Content Palette)
    • Personalization Picker (ibm.portal.Personalization.Picker.portlet)
    • Applications (wps.p.App Catalog)
    • Edit Layout (wps.p.Content Layout)
    • Members (wps.p.App Membership)
    • Roles (wps.p.App Roles)
    • Properties (wps.p.App Properties)
    • Parameters (wps.p.Template Parameters)
    • Application Layout (wps.p.Application Layout)
    • Application Template Library (wps.p.Template Library)
    • Portlet Wiring Tool (wps.p.Wiring)
    • Appearance portlet (wps.p.Appearance)
    • Page Locks (wps.p.Permissions)
    • Page Properties (wps.p.Properties)
    • Information Portlet (wps.p.Information)
    • Anonymous Information (wps.p.Information.Anonymous). Note: This portlet is hidden.
    • Policy Editor (wps.p.PolicyEditor)
    • Resource Policies (wps.p.PolicyExplorer)

By default the administration portlet Virtual Portal Manager is installed as part of the initial portal installation only. It is not part of the default content of virtual portals that you create. You can only use it in the initial portal installation.

Enjoy :-)

Wednesday, September 7, 2011

Performance guidelines for themes and skins

Use the following guidelines when making decisions that affect the development of your custom themes and skins. These guidelines describe the relative path length involved with the inclusion of various components of themes and skins. A number of the following changes are already implemented in the Portal theme. However, the functionality described is still supported and may have an impact on your design choices for your theme. To further aid in your design decisions, the Portal theme's approach to each guideline is listed in the following table:

Guidelines for a lightweight theme

Guideline

Effect on functionality

Effect on performance

Portal theme approach

Remove Show tools icon from the toolbar

Prevents users from displaying icons on pages and portlets used to arrange or remove content on the page.

High impact on pathlength required to generate the page

Show tools options are included through asynchronous context menus.

Remove enrollment icon from the toolbar

Prevents new visitors to the site from creating a new account for themselves.

High impact on pathlength required to generate the page

Enrollment included through asynchronous context menu.

Remove self care icon from the toolbar

Prevents users from updating account information.

High impact on pathlength required to generate the page

Edit Profile included through asynchronous context menu.

Remove AdminLinkBarInclude.jsp

Removes context-sensitive links that allow authorized users to create a new page, edit the current page, or assign permissions to the current page.

High impact on pathlength required to generate the page

These options are included through asynchronous context menu.

Remove and supporting code

Removes the ability for users to bookmark pages in the portal for quick retrievability

High impact on pathlength required to generate the page

Not included in the theme.

Shrink lines of text to remove white space

With some editors, white space might be used to aid in readability during theme development

Low impact on bandwidth required to transmit the page.

JSPs are left uncompacted for readability.

Change all HTML comments to JSP comments

None

Low impact on bandwidth required to transmit the page.

Mostly JSP comments used.

As noted earlier, not all of the above guidelines for the Portal theme may apply to all the available themes for WebSphere Portal. For example, the following guidelines do not apply to the Tab Menu - Page Builder theme:

  • Remove Show tools icon from the toolbar
  • Remove AdminLinkBarInclude.jsp
  • Remove and supporting code

Guides for a lightweight skin

Guideline

Effect on functionality

Effect on performance

IBM Skin approach

Remove minimize, restore, and maximize buttons

Prevents users from manipulating the size and state of the portlets on the page

High impact on pathlength required to generate the page

These options are included through asynchronous context menu.

Place the JSP tags for the Back, Edit, and Configure icons inside the tag.

No impact to users. Prevents unauthenticated (anonymous) users from attempting to access resources that are protected. For users that are logged in, this adds an extra JSP tag for processing. Processing of the tag has much less impact on performance than the access control checks to determine if a user has access to Edit and Configure portlet modes.

Medium impact on pathlength required to generate the page

None.

Shrink lines of text to remove white space

With some editors, white space might be used to aid in readability during skin development

Low impact on bandwidth required to transmit the page.

JSPs are left uncompacted for readability.

Remove drag and drop tags.

Users will be unable to drag and drop portlets on a page or from the Portlet Palette onto a page.

Medium impact on bandwidth required to transmit the page.

None.

Change all HTML comments to JSP comments

None

Low impact on bandwidth required to transmit the page.

Mostly JSP comments are already used.

As noted earlier, not all of the above guidelines for the IBM skin may apply to all the available skins for WebSphere Portal. For example, the Tab Menu - Page Builder theme does not use drag and drop tags. It uses the Dojo drag and drop framework. Hence, the Remove drag and drop tags guideline does not apply to the Tab Menu - Page Builder and the corresponding skins.

Note: If your starting point is the IBM skin, remember that portlet context menus are loaded asynchronously and the changes to the options available mentioned below (removing window state choices, surrounding in tag) will not affect the initial page size. The changes will affect the size of the page required to generate the contents of the portlet context menu.

Static resources

If possible, any CSS or Javascript that is included either in a theme, skin, portlet application, widget, or by any other extension should be built together either at buildtime or runtime, and then minimized and compressed to remove comments and unnecessary whitespace. This decreases the overall size of these files, reduces the number of HTTP requests the browser must make to aggregate the page, and reduces the load on the Web servers and Portal server. Using CSS sprites in themes, skins, and portlets can improve performance as well for the same reasons.