You must have gone through many articles to create Custom Event Handles by the time. But before actually creating custom event handler,keep the following points in mind:
1. Security:
The assembly you deploy to the Global Assembly Cache(GAC) is running with full trust. Watch out for the following:
• Denial of Service attack: If a user uploads 10000 items to a list, what is the effect it will have to the systems your assembly uses.
• SQL Injection attack: If a user attempts to insert SQL statements into a column of a list that your assembly uses to update a database, what mechanisms are you using to make sure the input is valid.
• Cross Site scripting attack: What is the effect of adding script to a column that your assembly uses to update another area in SharePoint?
2. Performance:
This is a important factor while building custom event handler.
• Load: What burden are you placing on your web front end servers to run the assembly each time an event occurs? Use performance counters to determine this.
• Long Running Operations: Consider creating a custom SharePoint timer job. Kick off/ Schedule the Timer Job from the event rather than running all the logic inside the event. This will allow you to use the features of SharePoint to view whether the Timer Job ran successfully.
• Sync vs Async Events: Synchronous events have to wait until your code completes before returning the page, whereas Asynchronous events show the page immediately.
3. Error Handling:
When using synchronous events and you decide to cancel an event, let the user know why the event was cancelled. For example, update a Task List with a message why it failed.
Log your errors so that you can determine what issue is occurring when your system is in production environment.
4. Connections:
Cater for external systems being down when you are trying to connect to them. Don’t let your code / solution go belly up because you cannot connect to a database.
5. Bulk Operations:
The MSDN documentation mentions that event handlers will not fire when bulk operation is occurring. For example, when a new list is created, the FieldAdding event will not fire.
So now you are ready to create a custom event handler successfully by keeping above points in mind.
You can also visit my other blogs to know about different topics:
Virtualization Concepts
Strong Named Assembly in SharePoint
SharePoint Taxonomy
SharePoint Object Model
Thursday, August 12, 2010
SharePoint 2010 Overview
SharePoint 2010 provides the business collaboration platform for developers to rapidly build solutions using familiar tools while leveraging a rich set of out of the box features. Visual Studio 2010 and SharePoint Designer 2010 make developers more productive and Visual Studio Team Foundation Server delivers support for application lifecycle management. Developers can integrate Line of Business data in SharePoint 2010 with read/write capability delivered by Business Connectivity Services. Sandboxed Solutions can be deployed to a shared hosting environment to limit the impact of unpredictable code to the other applications in use.
SharePoint:Extensibility Points-Web Parts, Master Pages, Pages, Delegate Controls, InfoPath Forms, and solutions leveraging the Word File Conversion Service. Access Services for deploying Access solutions to SharePoint.
Communities:
SharePoint:Out of the Box Features-The capability to locate and interact with people through expertise, relationships, tagging, and rating of content.
SharePoint:Extensibility Points-Predefined searches, search web parts, tagging interfaces, rating interfaces, and custom user interfaces.
Content:
SharePoint:Out of the Box Features-The capability to manage content whether that content is a web page, a document, or a set of documents and records management of the content that is created.
SharePoint:Extensibility Points-Custom page types, field controls, content types, document sets, remote blog storage providers, workflows and Word Services. Records management extensibility and Public Web Sites extensibility.
Search:
SharePoint:Out of the Box Features-The capability to search content inside and outside of SharePoint including information in structured database systems.
SharePoint:Extensibility Points-Predefined search result transformations, web parts leveraging search for navigation and location of content, and connections to back end systems. Also IFilters and Protocol Handlers.
Insights:
SharePoint:Out of the Box Feature-The capability to leverage Excel to access and display data on a web page, Dashboards, and Key Performance Indicators to transform raw data into actionable information.
SharePoint:Extensibility Points-Excel Services, Excel User defined functions, key performance indicators, and dashboards
Composite:
SharePoint:Out of the Box Feature-The capability for business users to create their own solutions through connection and arrangement of the features of the platform.
SharePoint:Extensibility Points-Web parts, workflows and InfoPath Forms Services that increase the tools available for the end user.
User Interface
The look and feel of SharePoint has radically changed from earlier versions of the product. In addition to being more accessible to the user it allows for improved extension points and fewer workarounds. The new user interface components that you can extend and build applications with include the fluent UI ribbon and an extensible dialog system. Figure shows the new home page for the default team site template in edit mode.
Multi-Browser Support
Microsoft says they recognize the need to support multiple browsers such as Safari and FireFox.
SharePoint 2010 Ribbon
The context sensitive ribbon interface is now integrated into the SharePoint 2010 user experience. Your applications can extend the ribbon interface to include new menu items and options both on a global level and based on the context of the user. Following figure shows how SharePoint changes the ribbon when a user selects a list web part. The arrow shows the addition of the List Tools section to the ribbon when the list web part is selected.
A serious challenge in user interface design for the web is the long page refresh times and the constant switching of context from one page to another. SharePoint 2010 has solved these concerns through the use of AJAX requests for partial updates and by providing a flexible popup dialog framework that allows you to pop up entry boxes on top of the existing page. Instead of having users navigate to a new page and then come back after the data entry is completed the user stays on the same page and a dialog appears above the page.
The dialogs are just pages which are loaded with a special master page and are therefore completely customizable by users and developers to meet their needs. Following figure shows a new announcement being entered in a dialog over a wiki web page.
The ability to set a theme for your look and feel within SharePoint is improved. Included is the ability to take your PowerPoint theme and upload and apply it to your SharePoint site.
If you are modifying a web page, you now have Live Preview capability, so you can see how the change will look before you actually accept it.
New Silverlight Web Part
There are times when the user interface needs to provide a level of interactivity that is simply not possible with XHTML technologies. That is where Silverlight steps in. Silverlight is the best way to leverage your .NET development skills in creating rich interactive experiences for the web. SharePoint now includes native support for Silverlight files. Simply develop your Silverlight application (.XAP) and deploy it to the server. You can then add the Silverlight application to your web page by adding the Silverlight web part and providing the location of the .XAP file. The Silverlight application is shown as a part of the page as in the example in following figure.
Empowering the Business
There are a couple of different ways to look at SharePoint 2010. Although the developer perspective is important, maybe the most critical is how it makes the lives of business users easier and lets them do more without the need for IT assistance.
Visio Integration
Use Visio 2010 for documenting and describing business processes? Now you can publish those diagrams directly to SharePoint with the back end connection remaining intact. So the view of the diagram is real time. What's nice about this capability is that not everyone needs to have a license for Visio to see the diagram.
SharePoint Designer 2010 is a fully functional participant in the solution creation lifecycle for SharePoint 2010. Applications can be created with the SharePoint web user interface and with SharePoint Designer 2010 as complete applications. Or they can be packaged into a SharePoint Solution (WSP) file that can be imported into and further edited by Visual Studio 2010. For example a declarative re-usable workflow can be prototyped in SharePoint Designer 2010 and moved in to Visual Studio 2010.
A site dashboard in SharePoint Designer 2010 allows you to see at a glance the basic information about the site. The navigation bar allows you to navigate into more details about the specific lists and libraries. Following figure shows the site dashboard for a site including the basic site information, permissions, and sub-sites.
SharePoint Designer 2010 Business Connectivity Services Design
Workflows operate on SharePoint data – or any data that SharePoint can operate on. Business Connectivity Services extends that reach of workflows and other SharePoint features to data outside of SharePoint. SharePoint Designer 2010 makes the process of defining external entities easy. A wizard guides you through making connections to an external system whether it is Windows Communication Foundation (WCF) Service, a Web Service, a .NET class, or a database. Once the connection is made you will see a list of the entities. By right clicking on the entity you can have SharePoint Designer automatically generate the actions needed to support the entity. Within just a few minutes you can create the connections for all of the tables in your database and connect those to external lists in SharePoint. Figure shows the AdventureWorks customer entity that was created by connecting to the Microsoft SQL Server AdventureWorks sample database.
Search
The addition of FAST to SharePoint gives a much improved search experience. Microsoft says their goal is to help you get the "right results on the first page". Those results include not only SharePoint content, but possibly business data and people — the Rich People Search Function from SharePoint 2007 will comes with SharePoint 2010.
Visit my other blogs also:
Checkpoints for creating Custom Event Handlers
Virtualization Concepts
SharePoint Taxonomy
Sites:
SharePoint:Out of the Box Features- The capability to store and retrieve both list and document content in an easy and flexible way with connectivity to the Microsoft Office client applications.SharePoint:Extensibility Points-Web Parts, Master Pages, Pages, Delegate Controls, InfoPath Forms, and solutions leveraging the Word File Conversion Service. Access Services for deploying Access solutions to SharePoint.
Communities:
SharePoint:Out of the Box Features-The capability to locate and interact with people through expertise, relationships, tagging, and rating of content.
SharePoint:Extensibility Points-Predefined searches, search web parts, tagging interfaces, rating interfaces, and custom user interfaces.
Content:
SharePoint:Out of the Box Features-The capability to manage content whether that content is a web page, a document, or a set of documents and records management of the content that is created.
SharePoint:Extensibility Points-Custom page types, field controls, content types, document sets, remote blog storage providers, workflows and Word Services. Records management extensibility and Public Web Sites extensibility.
Search:
SharePoint:Out of the Box Features-The capability to search content inside and outside of SharePoint including information in structured database systems.
SharePoint:Extensibility Points-Predefined search result transformations, web parts leveraging search for navigation and location of content, and connections to back end systems. Also IFilters and Protocol Handlers.
Insights:
SharePoint:Out of the Box Feature-The capability to leverage Excel to access and display data on a web page, Dashboards, and Key Performance Indicators to transform raw data into actionable information.
SharePoint:Extensibility Points-Excel Services, Excel User defined functions, key performance indicators, and dashboards
Composite:
SharePoint:Out of the Box Feature-The capability for business users to create their own solutions through connection and arrangement of the features of the platform.
SharePoint:Extensibility Points-Web parts, workflows and InfoPath Forms Services that increase the tools available for the end user.
User Interface
The look and feel of SharePoint has radically changed from earlier versions of the product. In addition to being more accessible to the user it allows for improved extension points and fewer workarounds. The new user interface components that you can extend and build applications with include the fluent UI ribbon and an extensible dialog system. Figure shows the new home page for the default team site template in edit mode.
Building User Interface
SharePoint 2010 leverages wiki concepts for managing content and extends these concepts by allowing for the inclusion of web parts within the wiki pages themselves. In previous versions you were allowed to add web parts to web part zones. In SharePoint 2010 the developer (and the user) has compete control of the user interface including the placement of web parts anywhere on the page. For instance, this means that it is possible to put the results of a survey next to text describing the survey. So the results of code and content can be comingled on the page to create rich live content scenarios. Multi-Browser Support
Microsoft says they recognize the need to support multiple browsers such as Safari and FireFox.
SharePoint 2010 Ribbon
The context sensitive ribbon interface is now integrated into the SharePoint 2010 user experience. Your applications can extend the ribbon interface to include new menu items and options both on a global level and based on the context of the user. Following figure shows how SharePoint changes the ribbon when a user selects a list web part. The arrow shows the addition of the List Tools section to the ribbon when the list web part is selected.
SharePoint 2010 Dialog Framework
A serious challenge in user interface design for the web is the long page refresh times and the constant switching of context from one page to another. SharePoint 2010 has solved these concerns through the use of AJAX requests for partial updates and by providing a flexible popup dialog framework that allows you to pop up entry boxes on top of the existing page. Instead of having users navigate to a new page and then come back after the data entry is completed the user stays on the same page and a dialog appears above the page.
The dialogs are just pages which are loaded with a special master page and are therefore completely customizable by users and developers to meet their needs. Following figure shows a new announcement being entered in a dialog over a wiki web page.
Live Preview & Themes
The ability to set a theme for your look and feel within SharePoint is improved. Included is the ability to take your PowerPoint theme and upload and apply it to your SharePoint site.
If you are modifying a web page, you now have Live Preview capability, so you can see how the change will look before you actually accept it.
New Silverlight Web Part
There are times when the user interface needs to provide a level of interactivity that is simply not possible with XHTML technologies. That is where Silverlight steps in. Silverlight is the best way to leverage your .NET development skills in creating rich interactive experiences for the web. SharePoint now includes native support for Silverlight files. Simply develop your Silverlight application (.XAP) and deploy it to the server. You can then add the Silverlight application to your web page by adding the Silverlight web part and providing the location of the .XAP file. The Silverlight application is shown as a part of the page as in the example in following figure.
Empowering the Business
There are a couple of different ways to look at SharePoint 2010. Although the developer perspective is important, maybe the most critical is how it makes the lives of business users easier and lets them do more without the need for IT assistance.
Visio Integration
Use Visio 2010 for documenting and describing business processes? Now you can publish those diagrams directly to SharePoint with the back end connection remaining intact. So the view of the diagram is real time. What's nice about this capability is that not everyone needs to have a license for Visio to see the diagram.
SharePoint Designer 2010
SharePoint Designer 2010 is a fully functional participant in the solution creation lifecycle for SharePoint 2010. Applications can be created with the SharePoint web user interface and with SharePoint Designer 2010 as complete applications. Or they can be packaged into a SharePoint Solution (WSP) file that can be imported into and further edited by Visual Studio 2010. For example a declarative re-usable workflow can be prototyped in SharePoint Designer 2010 and moved in to Visual Studio 2010.
A site dashboard in SharePoint Designer 2010 allows you to see at a glance the basic information about the site. The navigation bar allows you to navigate into more details about the specific lists and libraries. Following figure shows the site dashboard for a site including the basic site information, permissions, and sub-sites.
SharePoint Designer 2010 Business Connectivity Services Design
Workflows operate on SharePoint data – or any data that SharePoint can operate on. Business Connectivity Services extends that reach of workflows and other SharePoint features to data outside of SharePoint. SharePoint Designer 2010 makes the process of defining external entities easy. A wizard guides you through making connections to an external system whether it is Windows Communication Foundation (WCF) Service, a Web Service, a .NET class, or a database. Once the connection is made you will see a list of the entities. By right clicking on the entity you can have SharePoint Designer automatically generate the actions needed to support the entity. Within just a few minutes you can create the connections for all of the tables in your database and connect those to external lists in SharePoint. Figure shows the AdventureWorks customer entity that was created by connecting to the Microsoft SQL Server AdventureWorks sample database.
Search
The addition of FAST to SharePoint gives a much improved search experience. Microsoft says their goal is to help you get the "right results on the first page". Those results include not only SharePoint content, but possibly business data and people — the Rich People Search Function from SharePoint 2007 will comes with SharePoint 2010.
Visit my other blogs also:
Checkpoints for creating Custom Event Handlers
Virtualization Concepts
SharePoint Taxonomy
Infix to Postfix Conversion
Infix postfix operations include interconversion of expressions. Let us know about Infix to Postfix Conversion in brief.
Infix Expression:
Any expression in the standard form like "2*3-4/5" is an Infix (Inorder) expression.
Postfix Expression:
The Postfix (Postorder) form of the above expression is "23*45/-".
Infix to Postfix Conversion:
In normal algebra we use the infix notation like a+b*c. The corresponding postfix notation is abc*+. The algorithm for the infix to postfix conversion is as follows:
• Scan the Infix string from left to right.
• Initialize an empty stack.
• If the scanned character is an operand, add it to the Postfix string. If the scanned character is an operator and if the stack is empty Push the character to stack.
• If the scanned character is an Operand and the stack is not empty, compare the precedence of the character with the element on top of the stack (topStack). If topStack has higher precedence over the scanned character Pop the stack else Push the scanned character to stack. Repeat this step as long as stack is not empty and topStack has precedence over the character. Repeat this step till all the characters are scanned.
• (After all characters are scanned, we have to add any character that the stack may have to the Postfix string.) If stack is not empty,add topStack to Postfix string and Pop the stack. Repeat this step as long as stack is not empty.
• Return the Postfix string.
Example for Infix to Postfix Conversion:
Let us see how the above algorithm will be implemented using an example.
Infix String: a+b*c-d
Initially the Stack is empty and our Postfix string has no characters. Now, the first character scanned is 'a'. 'a' is added to the Postfix string. The next character scanned is '+'. It being an operator, it is pushed to the stack.
• Infix String : a+b*c-d
• Postfix String : abc*+d-
This was the simple way for Infix to Postfix conversion
Feel free to read my blogs:
Virtualization Concepts
SharePoint Taxonomy
Checkpoints for creating Custom Event Handlers
Infix Expression:
Any expression in the standard form like "2*3-4/5" is an Infix (Inorder) expression.
Postfix Expression:
The Postfix (Postorder) form of the above expression is "23*45/-".
Infix to Postfix Conversion:
In normal algebra we use the infix notation like a+b*c. The corresponding postfix notation is abc*+. The algorithm for the infix to postfix conversion is as follows:
• Scan the Infix string from left to right.
• Initialize an empty stack.
• If the scanned character is an operand, add it to the Postfix string. If the scanned character is an operator and if the stack is empty Push the character to stack.
• If the scanned character is an Operand and the stack is not empty, compare the precedence of the character with the element on top of the stack (topStack). If topStack has higher precedence over the scanned character Pop the stack else Push the scanned character to stack. Repeat this step as long as stack is not empty and topStack has precedence over the character. Repeat this step till all the characters are scanned.
• (After all characters are scanned, we have to add any character that the stack may have to the Postfix string.) If stack is not empty,add topStack to Postfix string and Pop the stack. Repeat this step as long as stack is not empty.
• Return the Postfix string.
Example for Infix to Postfix Conversion:
Let us see how the above algorithm will be implemented using an example.
Infix String: a+b*c-d
Initially the Stack is empty and our Postfix string has no characters. Now, the first character scanned is 'a'. 'a' is added to the Postfix string. The next character scanned is '+'. It being an operator, it is pushed to the stack.
Next character scanned is 'b' which will be placed in the Postfix string. Next character is '*' which is an operator. Now, the top element of the stack is '+' which has lower precedence than '*', so '*' will be pushed to the stack.
The next character is 'c' which is placed in the Postfix string. Next character scanned is '-'. The topmost character in the stack is '*' which has a higher precedence than '-'. Thus '*' will be popped out from the stack and added to the Postfix string. Even now the stack is not empty. Now the topmost element of the stack is '+' which has equal priority to '-'. So pop the '+' from the stack and add it to the Postfix string. The '-' will be pushed to the stack.
Next character is ’d’ which is added to Postfix string. Now all characters have been scanned so we must pop the remaining elements from the stack and add it to the Postfix string. At this stage we have only a '-' in the stack. It is popped out and added to the Postfix string. So, after all characters are scanned, this is how the stack and Postfix string will be:
End result:
• Infix String : a+b*c-d
• Postfix String : abc*+d-
This was the simple way for Infix to Postfix conversion
Feel free to read my blogs:
Virtualization Concepts
SharePoint Taxonomy
Checkpoints for creating Custom Event Handlers
Virtualization Concepts
What is Virtualization?
Virtualization is a proven software technology that is rapidly transforming the IT landscape and fundamentally changing the way that people compute. Today’s powerful x86 computer hardware was designed to run a single operating system and a single application. This leaves most machines vastly underutilized. Virtualization concept lets you run multiple virtual machines on a single physical machine, sharing the resources of that single computer across multiple environments. Different virtual machines can run different operating systems and multiple applications on the same physical computer. Virtualizaion technology is production-proven, used by more than 170,000 customers, including 100% of the Fortune 100.
Virtual Machine Definition:
A virtual machine (VM) is an environment in virtualization concept,is usually a program or operating system, which does not physically exist but is created within another environment. In this context, a VM is called a "guest" while the environment it runs within is called a "host." Virtual machines are often created to execute an instruction set different than that of the host environment. One host environment can often run multiple VMs at once. Because VMs are separated from the physical resources they use, the host environment is often able to dynamically assign those resources among them
Pre-requisites for installing Microsoft Virtual Server 2005 R2:
x86 based 1GHz processor with L2 cache
Super VGA monitor
Network interface card
Min. 1GB-2GB RAM
5GB HDD files space
IIS enabled
Top 5 Reasons to Adopt Virtualization Software:
1. Get more out of your existing resources: Pool common infrastructure resources and break the legacy “one application to one server” model with server consolidation.
2. Reduce datacenter costs by reducing your physical infrastructure and improving your server to admin ratio: Fewer servers and related IT hardware means reduced real estate and reduced power and cooling requirements. Better management tools let you improve your server to admin ratio so personnel requirements are reduced as well.
3. Increase availability of hardware and applications for improved business continuity: Securely backup and migrate entire virtual environments with no interruption in service. Eliminate planned downtime and recover immediately from unplanned issues.
4. Gain operational flexibility: Respond to market changes with dynamic resource management, faster server provisioning and improved desktop and application deployment.
5. Improve desktop manageability and security: Deploy, manage and monitor secure desktop environments that users can access locally or remotely, with or without a network connection, on almost any standard desktop, laptop or tablet PC.
What is a Virtual Machine?
An operating system can’t tell the difference between a virtual machine and a physical machine, nor can applications or other computers on a network. Even the virtual machine thinks it is a “real” computer. Nevertheless, a virtual machine is composed entirely of software and contains no hardware components whatsoever. As a result, virtual machines offer a number of distinct advantages over physical hardware.
Types of Virtual Machine based on their use and degree of correspondence to any real machine:
1) System Virtual Machine:
A system virtual machine provides a complete system platform which supports the execution of a complete operating system (OS).
System virtual machines (sometimes called hardware virtual machines) allow the sharing of the underlying physical machine resources between different virtual machines, each running its own operating system. The software layer providing the virtualization is called a virtual machine monitor or hypervisor. A hypervisor can run on bare hardware (Type 1 or native VM) or on top of an operating system (Type 2 or hosted VM).
The main advantages of system VMs are:
• multiple OS environments can co-exist on the same computer, in strong isolation from each other
• the virtual machine can provide an instruction set architecture (ISA) that is somewhat different from that of the real machine
• application provisioning, maintenance, high availability and disaster recovery
The main disadvantage of system VMs is: a virtual machine is less efficient than a real machine because it accesses the hardware indirectly
2) Process Virtual Machine:
A process virtual machine is designed to run a single program, which means that it supports a single process.
A process VM, sometimes called an application virtual machine, runs as a normal application inside an OS and supports a single process. It is created when that process is started and destroyed when it exits. Its purpose is to provide a platform-independent programming environment that abstracts away details of the underlying hardware or operating system, and allows a program to execute in the same way on any platform. A process VM provides a high-level abstraction — that of a high-level programming language (compared to the low-level ISA abstraction of the system VM). Process VMs are implemented using an interpreter; performance comparable to compiled programming languages is achieved by the use of just-in-time compilation.
What is a Virtual Infrastructure?
A virtual infrastructure consists of the following components:
• Bare-metal hypervisors to enable full virtualization of each x86 computer.
• Virtual infrastructure services such as resource management and consolidated backup to optimize available resources among virtual machines
• Automation solutions that provide special capabilities to optimize a particular IT process such as provisioning or disaster recovery.
Decouple your software environment from its underlying hardware infrastructure so you can aggregate multiple servers, storage infrastructure and networks into shared pools of resources. Then dynamically deliver those resources, securely and reliably, to applications as needed. This pioneering approach lets our customers use building blocks of inexpensive industry-standard servers to build a self-optimizing datacenter and deliver high levels of utilization, availability, automation and flexibility.
This gives you brief idea about virtualization concept. I hops this was helpful to you.
Refer my other blogs for other topics:
SharePoint Taxonomy
Checkpoints for creating Custom Event Handlers
Strong Named Assembly in SharePoint
Virtualization is a proven software technology that is rapidly transforming the IT landscape and fundamentally changing the way that people compute. Today’s powerful x86 computer hardware was designed to run a single operating system and a single application. This leaves most machines vastly underutilized. Virtualization concept lets you run multiple virtual machines on a single physical machine, sharing the resources of that single computer across multiple environments. Different virtual machines can run different operating systems and multiple applications on the same physical computer. Virtualizaion technology is production-proven, used by more than 170,000 customers, including 100% of the Fortune 100.
Virtual Machine Definition:
A virtual machine (VM) is an environment in virtualization concept,is usually a program or operating system, which does not physically exist but is created within another environment. In this context, a VM is called a "guest" while the environment it runs within is called a "host." Virtual machines are often created to execute an instruction set different than that of the host environment. One host environment can often run multiple VMs at once. Because VMs are separated from the physical resources they use, the host environment is often able to dynamically assign those resources among them
Pre-requisites for installing Microsoft Virtual Server 2005 R2:
x86 based 1GHz processor with L2 cache
Super VGA monitor
Network interface card
Min. 1GB-2GB RAM
5GB HDD files space
IIS enabled
Top 5 Reasons to Adopt Virtualization Software:
1. Get more out of your existing resources: Pool common infrastructure resources and break the legacy “one application to one server” model with server consolidation.
2. Reduce datacenter costs by reducing your physical infrastructure and improving your server to admin ratio: Fewer servers and related IT hardware means reduced real estate and reduced power and cooling requirements. Better management tools let you improve your server to admin ratio so personnel requirements are reduced as well.
3. Increase availability of hardware and applications for improved business continuity: Securely backup and migrate entire virtual environments with no interruption in service. Eliminate planned downtime and recover immediately from unplanned issues.
4. Gain operational flexibility: Respond to market changes with dynamic resource management, faster server provisioning and improved desktop and application deployment.
5. Improve desktop manageability and security: Deploy, manage and monitor secure desktop environments that users can access locally or remotely, with or without a network connection, on almost any standard desktop, laptop or tablet PC.
What is a Virtual Machine?
A virtual machine is a tightly isolated software container that can run its own operating systems and applications as if it were a physical computer. A virtual machine behaves exactly like a physical computer and contains it own virtual (i.e., software-based) CPU, RAM hard disk and network interface card (NIC).
An operating system can’t tell the difference between a virtual machine and a physical machine, nor can applications or other computers on a network. Even the virtual machine thinks it is a “real” computer. Nevertheless, a virtual machine is composed entirely of software and contains no hardware components whatsoever. As a result, virtual machines offer a number of distinct advantages over physical hardware.
Types of Virtual Machine based on their use and degree of correspondence to any real machine:
1) System Virtual Machine:
A system virtual machine provides a complete system platform which supports the execution of a complete operating system (OS).
System virtual machines (sometimes called hardware virtual machines) allow the sharing of the underlying physical machine resources between different virtual machines, each running its own operating system. The software layer providing the virtualization is called a virtual machine monitor or hypervisor. A hypervisor can run on bare hardware (Type 1 or native VM) or on top of an operating system (Type 2 or hosted VM).
The main advantages of system VMs are:
• multiple OS environments can co-exist on the same computer, in strong isolation from each other
• the virtual machine can provide an instruction set architecture (ISA) that is somewhat different from that of the real machine
• application provisioning, maintenance, high availability and disaster recovery
The main disadvantage of system VMs is: a virtual machine is less efficient than a real machine because it accesses the hardware indirectly
2) Process Virtual Machine:
A process virtual machine is designed to run a single program, which means that it supports a single process.
A process VM, sometimes called an application virtual machine, runs as a normal application inside an OS and supports a single process. It is created when that process is started and destroyed when it exits. Its purpose is to provide a platform-independent programming environment that abstracts away details of the underlying hardware or operating system, and allows a program to execute in the same way on any platform. A process VM provides a high-level abstraction — that of a high-level programming language (compared to the low-level ISA abstraction of the system VM). Process VMs are implemented using an interpreter; performance comparable to compiled programming languages is achieved by the use of just-in-time compilation.
What is a Virtual Infrastructure?
A virtual infrastructure lets you share your physical resources of multiple machines across your entire infrastructure. A virtual machine lets you share the resources of a single physical computer across multiple virtual machines for maximum efficiency. Resources are shared across multiple virtual machines and applications. Your business needs are the driving force behind dynamically mapping the physical resources of your infrastructure to applications—even as those needs evolve and change. Aggregate your x86 servers along with network and storage into a unified pool of IT resources that can be utilized by the applications when and where they’re needed. This resource optimization drives greater flexibility in the organization and results in lower capital and operational costs.
A virtual infrastructure consists of the following components:
• Bare-metal hypervisors to enable full virtualization of each x86 computer.
• Virtual infrastructure services such as resource management and consolidated backup to optimize available resources among virtual machines
• Automation solutions that provide special capabilities to optimize a particular IT process such as provisioning or disaster recovery.
Decouple your software environment from its underlying hardware infrastructure so you can aggregate multiple servers, storage infrastructure and networks into shared pools of resources. Then dynamically deliver those resources, securely and reliably, to applications as needed. This pioneering approach lets our customers use building blocks of inexpensive industry-standard servers to build a self-optimizing datacenter and deliver high levels of utilization, availability, automation and flexibility.
This gives you brief idea about virtualization concept. I hops this was helpful to you.
Refer my other blogs for other topics:
SharePoint Taxonomy
Checkpoints for creating Custom Event Handlers
Strong Named Assembly in SharePoint
Strong Named Assembly in SharePoint
What is Strong Name?
A strong name is a .NET assembly name combined with its version number and other information to uniquely identify the assembly. This allows multiple versions of the same assembly to peacefully co-exist in the global assembly cache, where shared assemblies are typically stored.
A strong name consists of five parts:
1) Simple Name – Usually the name of the file (without the extension) that contains the assembly
2) Public Key – RSA cryptographic public key that helps verify the assembly's authenticity
3) Version – Four-part version number, in the form of Major.Minor.Build.Revision
4) Culture – Target audience for the assembly, such as "neutral" (default audience), "en-us" (English – United States) or "fr" (France) etc.
5) Processor Architecture – Defines the assembly's format, such as MSIL (intermediate language) or x86 (binary for Intel x86 processors)
An example of Strong Named Assembly:
Strong name is "Mini-Launcher, Version=0.3.612.24542, Culture=neutral, PublicKeyToken=ffa52ed9739048b4, ProcessorArchitecture=MSIL"
Why Use Strong Names?
Strong names are required to store shared assemblies in the global assembly cache (GAC). This is because the GAC allows multiple versions of the same assembly to reside on your system simultaneously, so that each application can find and use its own version of your assembly. This helps avoid DLL Hell, where applications that may be compiled to different versions of your assembly could potentially break because they are all forced to use the same version of your assembly.
Another reason to use strong names is to make it difficult for hackers to spoof your assembly, in other words, replace or inject your assembly with a virus or malicious code.
You can ensure that a name is globally unique by signing an assembly with a strong name.
Strong names satisfy following requirements:
1) Strong names guarantee name uniqueness by relying on unique key pairs. No one can generate the same assembly name that you can, because an assembly generated with one private key has a different name than an assembly generated with another private key.
2) Strong names protect the version lineage of an assembly. A strong name can ensure that no one can produce a subsequent version of your assembly. Users can be sure that a version of the assembly they are loading comes from the same publisher that created the version the application was built with.
3) Strong names provide a strong integrity check. Passing the .NET Framework security checks guarantees that the contents of the assembly have not been changed since it was built. Note, however, that strong names in and of themselves do not imply a level of trust like that provided, for example, by a digital signature and supporting certificate.
What is a strong name key file?
A strong name key file has a .snk extension and contains a unique public-private key pair. You use the strong name key file to digitally sign your assembly (see below). Note that this type of file is not secure, as the private key in a .snk file can be easily compromised.
For added protection, Visual Studio can encrypt a strong name key file, which produces a file with the .pfx (Personal Information eXchange) extension. The .pfx file is more secure because whenever someone attempts to use the encrypted key, she will be prompted for the password.
How do I create a strong name key file for a .NET assembly?
1) Select your assembly project in the Visual Studio 2008 Solution Explorer.
2) Click the Properties button. The project properties will appear in the main window.
3) Select the Signing tab:
5) In the Choose a strong name key file drop-down, select New. The "Create Strong Name Key" dialog appears:
7) If desired, you can protect the strong name key file with a password. To do so, check the Protect my key file with a password checkbox, then enter and confirm the password.
8) Click the OK button.
How to get Strong Named Token?
1) Go to External Tools... from Tools menu.
4) Click Apply to get the new tool in Tools menu to get SN Token.
Finally check the received SN token entry in GAC by right clicking the entry. You can see the desired result as follows:
A strong name is a .NET assembly name combined with its version number and other information to uniquely identify the assembly. This allows multiple versions of the same assembly to peacefully co-exist in the global assembly cache, where shared assemblies are typically stored.
A strong name consists of five parts:
1) Simple Name – Usually the name of the file (without the extension) that contains the assembly
2) Public Key – RSA cryptographic public key that helps verify the assembly's authenticity
3) Version – Four-part version number, in the form of Major.Minor.Build.Revision
4) Culture – Target audience for the assembly, such as "neutral" (default audience), "en-us" (English – United States) or "fr" (France) etc.
5) Processor Architecture – Defines the assembly's format, such as MSIL (intermediate language) or x86 (binary for Intel x86 processors)
An example of Strong Named Assembly:
Strong name is "Mini-Launcher, Version=0.3.612.24542, Culture=neutral, PublicKeyToken=ffa52ed9739048b4, ProcessorArchitecture=MSIL"
Why Use Strong Names?
Strong names are required to store shared assemblies in the global assembly cache (GAC). This is because the GAC allows multiple versions of the same assembly to reside on your system simultaneously, so that each application can find and use its own version of your assembly. This helps avoid DLL Hell, where applications that may be compiled to different versions of your assembly could potentially break because they are all forced to use the same version of your assembly.
Another reason to use strong names is to make it difficult for hackers to spoof your assembly, in other words, replace or inject your assembly with a virus or malicious code.
You can ensure that a name is globally unique by signing an assembly with a strong name.
Strong names satisfy following requirements:
1) Strong names guarantee name uniqueness by relying on unique key pairs. No one can generate the same assembly name that you can, because an assembly generated with one private key has a different name than an assembly generated with another private key.
2) Strong names protect the version lineage of an assembly. A strong name can ensure that no one can produce a subsequent version of your assembly. Users can be sure that a version of the assembly they are loading comes from the same publisher that created the version the application was built with.
3) Strong names provide a strong integrity check. Passing the .NET Framework security checks guarantees that the contents of the assembly have not been changed since it was built. Note, however, that strong names in and of themselves do not imply a level of trust like that provided, for example, by a digital signature and supporting certificate.
What is a strong name key file?
A strong name key file has a .snk extension and contains a unique public-private key pair. You use the strong name key file to digitally sign your assembly (see below). Note that this type of file is not secure, as the private key in a .snk file can be easily compromised.
For added protection, Visual Studio can encrypt a strong name key file, which produces a file with the .pfx (Personal Information eXchange) extension. The .pfx file is more secure because whenever someone attempts to use the encrypted key, she will be prompted for the password.
How do I create a strong name key file for a .NET assembly?
1) Select your assembly project in the Visual Studio 2008 Solution Explorer.
2) Click the Properties button. The project properties will appear in the main window.
3) Select the Signing tab:
4) Check the Sign the assembly checkbox.
5) In the Choose a strong name key file drop-down, select New. The "Create Strong Name Key" dialog appears:
6) In the Key file name text box, type the desired key name. Typically this is the name of your assembly but can be anything. Visual Studio will automatically append the proper file extension.
8) Click the OK button.
How to get Strong Named Token?
1) Go to External Tools... from Tools menu.
2) Click Add.
3) enter the Title, Commands (SDK path of sn.ese) and Arguments. 4) Click Apply to get the new tool in Tools menu to get SN Token.
Finally check the received SN token entry in GAC by right clicking the entry. You can see the desired result as follows:
This is the simple way to create and get the Strong Named Assembly in SharePoint. It is not too different from the strong named assembly in dot net.
Thank you for reading my blog. Please go through my other blogs:
SharePoint Taxonomy
What is Taxonomy?
Taxonomy is the practice and science of classification. The word finds its roots in the Greek τάξις, taxis (meaning 'order', 'arrangement') and νόμος, nomos ('law' or 'science'). It is the science of classification according to a pre-determined system, with the resulting catalog used to provide a conceptual framework for discussion, analysis, or information retrieval.
What is SharePoint Taxonomy?
In context of SharePoint taxonomy, we usually get many questions related to SharePoint website. Some of them I have listed below:
1. What type of content does the site contain?
2. Who can view the site?
3. Who can manage the site?
4. Who can publish content to the site?
5. What is the site’s URL?
6. How much space can the site consume?
7. What does the site look like?
8. How long should the site remain active?
All these questions are successfully answered by creating SharePoint Taxonomy.
SharePoint Taxonomy basically deals with data (aka. metadata) as well as the policies, workflows, permissions, etc.
Following is the sample SharePoint Taxonomy metadata:
With the exponential growth of implementations worldwide, come greater challenges and opportunities for improving knowledge management and information access within the enterprise. The need for consistent organizing principles across enterprise information is of ever increasing importance and, when done correctly, can result in leaps and bounds in employee productivity.
Before we get to any of the details however, let’s remind ourselves that the purpose of building and maintaining taxonomies is to improve the find ability of information by:
-Defining preferred terms along with their synonyms and variants;
-Establishing equivalent, hierarchical, associative or custom relationships between those terms;
-Increasing the effectiveness of site navigation; and
-Enhancing enterprise search by leveraging functionality such as faceted navigation.
The first and cost effective approach is to leverage features and functionality inherently part of the platform itself. Doing so means the implementation of sharepoint taxonomy is done through a combination of site content types, column definitions and custom lists.
A typical implementation of taxonomy might look something like this: As an administrator you navigate to the root or site collection settings and do the following:
1. Define SharePoint Taxonomy Metadata – Create custom site lists to be used for the management of metadata attributes you want to surface as controlled vocabularies for your site users.
2. Define Site Columns – Create new site columns that get their information from the custom lists created above via lookup fields.
3. Define Content Types – Create new site content types and add the appropriate site columns as required.
4. Allow the Management of Content Types – Enable the management of content types on site lists and libraries that require these consistent organizing principles.
-Document libraries and lists
-Analyze document usage
-Plan document libraries
-Plan lists
-Plan enterprise content storage
-Site Navigation
-Metadata
-Content types
-Information management policies (Labels, Barcodes, Auditing, Expiration)
-Records management
-Moving content
-Plan content deployment
-Workflows
-Site Templates
-Working with site templates and definitions
-Content approval
-Versioning
-Check-outs
-Standardization across sites
-People and groups (permissions)
The SharePoint taxonomy provides much more than a common set of terms, it provides a foundation upon which future decisions are made. It provides a scalable hierarchy that allows a SharePoint deployment to grow in an organized, predictable, and understandable manner.
You can visit my other blogs:
Virtualization Concepts
Strong Named Assembly in SharePoint
Taxonomy is the practice and science of classification. The word finds its roots in the Greek τάξις, taxis (meaning 'order', 'arrangement') and νόμος, nomos ('law' or 'science'). It is the science of classification according to a pre-determined system, with the resulting catalog used to provide a conceptual framework for discussion, analysis, or information retrieval.
What is SharePoint Taxonomy?
In context of SharePoint taxonomy, we usually get many questions related to SharePoint website. Some of them I have listed below:
1. What type of content does the site contain?
2. Who can view the site?
3. Who can manage the site?
4. Who can publish content to the site?
5. What is the site’s URL?
6. How much space can the site consume?
7. What does the site look like?
8. How long should the site remain active?
All these questions are successfully answered by creating SharePoint Taxonomy.
SharePoint Taxonomy basically deals with data (aka. metadata) as well as the policies, workflows, permissions, etc.
Following is the sample SharePoint Taxonomy metadata:
Before we get to any of the details however, let’s remind ourselves that the purpose of building and maintaining taxonomies is to improve the find ability of information by:
-Defining preferred terms along with their synonyms and variants;
-Establishing equivalent, hierarchical, associative or custom relationships between those terms;
-Increasing the effectiveness of site navigation; and
-Enhancing enterprise search by leveraging functionality such as faceted navigation.
The first and cost effective approach is to leverage features and functionality inherently part of the platform itself. Doing so means the implementation of sharepoint taxonomy is done through a combination of site content types, column definitions and custom lists.
A typical implementation of taxonomy might look something like this: As an administrator you navigate to the root or site collection settings and do the following:
1. Define SharePoint Taxonomy Metadata – Create custom site lists to be used for the management of metadata attributes you want to surface as controlled vocabularies for your site users.
2. Define Site Columns – Create new site columns that get their information from the custom lists created above via lookup fields.
3. Define Content Types – Create new site content types and add the appropriate site columns as required.
4. Allow the Management of Content Types – Enable the management of content types on site lists and libraries that require these consistent organizing principles.
We should have a sample check-list of items of what needs to be done to implement a SharePoint site. . The list of items can be extremely detailed, but to some degree they needed a simple list just so they could get started and know what needs to get done and when they will have to spent more time on. Here is that simple list. This is your “get started” list that you should incorporate into your project timeline.
-Document libraries and lists
-Analyze document usage
-Plan document libraries
-Plan lists
-Plan enterprise content storage
-Site Navigation
-Metadata
-Content types
-Information management policies (Labels, Barcodes, Auditing, Expiration)
-Records management
-Moving content
-Plan content deployment
-Workflows
-Site Templates
-Working with site templates and definitions
-Content approval
-Versioning
-Check-outs
-Standardization across sites
-People and groups (permissions)
The SharePoint taxonomy provides much more than a common set of terms, it provides a foundation upon which future decisions are made. It provides a scalable hierarchy that allows a SharePoint deployment to grow in an organized, predictable, and understandable manner.
You can visit my other blogs:
Virtualization Concepts
Strong Named Assembly in SharePoint
Subscribe to:
Posts (Atom)