newtelligence poweredRSS 2.0
# Tuesday, February 02, 2010

IIS 7 introduced the concept of the Application Pool Identity, but it was not used by default. This was changed in IIS 7.5, and it is a change I fully endorse. The Application Pool Identity is a special account that is created per application pool which adds additional process isolation between your application pools.

The tricky thing is granting permissions to this special account. The account has a fully qualified name of “IIS AppPool\ApplicationPoolName”. However I was unable to get this account to be added via the GUI. I needed to resort to the command line tool icacls, which has a grant syntax of:

icacls path /grant “IIS AppPool\ApplicationPoolName”:RX

This will add the user with “special permissions” for reading. After you do this, the account shows up in the GUI and you can go in and just check the standard boxes for read rights (Read & Execute, List Folder contents, Read). Once you check these boxes the special read permissions that were initially set are removed, and everything looks like it usually does.

For network access, the AppPoolIdentity accesses the network using the machine’s domain account which is DomainName\MachineName$. The article says that this is how NetworkService worked, and that this makes it easy to add ACLs by just granting them to the Machine Account. Maybe I am unnecessarily paranoid, but I would prefer to grant access to network resource on a per app pool basis, which most likely requires a separate domain account. However, since I do not need network access right now, I will proceed with the AppPool Identity and write a follow-up post when I need to go down the domain account path.

You can read more about the AppPool Identity here: http://learn.iis.net/page.aspx/624/application-pool-identities/

Tuesday, February 02, 2010 8:46:42 PM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
Technology

I have been meaning to write this for a couple of weeks now, my year in review and what's in store for 2010. Unfortunately I ended up in the hospital with a ruptured appendix and a minor complication that kept me there for 8 days.

Year in Review
2009 was a pretty good year for me. I started competing in the sport of Triathlon, finishing well in 2 half iron distance and 2 Olympic distance events.

My 2009 race schedule was to get some experience before attempting Ironman Wisconsin in 2010. I am pretty set on gear, with all my major purchases completed last year, and the last big one (Power meter) I just took care of. I picked up a used Argon 18 E-114, Kurt Kinetic Indoor trainer, Nineteen Frequency Wetsuit, Garmin Forerunner 305 GPS and just ordered a Powertap SL+ system. I gained a lot of valuable experience during my 09 races, and I am excited to see how much I can improve over last year. The biggest thing I learned was that my bike volume was not high enough to support the bike effort I was attempting on race day.

On the professional side of things, I finally got off the side lines and presented at the Madison .Net User group on Sharepoint 2010. For my first presentation, I think I did an ok job and the feedback I got was mainly positive. I still need to get my free copy of resharper so I can give it one more try. Also on the professional side, I accepted a new position as a Software Engineer with a new startup called Madison Research Technologies (MRT). MRT is working on developing a technical solution to a costly problem in the health care industry. I'll be able to talk about it more once we launch the product. I can tell you that I’m using a Microsoft Stack (what else would I be using) consisting of Asp.Net MVC and SQL Server.

To end my year right, and to get me psyched for Ironman training, my body thought it would fun to put me in the hospital for a week with a ruptured appendix and a pretty serious case of Ileus. I got the NG tube passed up the nose (while awake) and didn’t get any food for almost a week. By the time I got home, I had lost 7 pounds, and no it wasn’t water weight, seeing as I was on an IV continuously.

2010

The biggest thing I have going in 2010 is my first Ironman, Ironman Wisconsin, on September 12th. I just had my first full week of training the last week in January. Since that was an “off” week, it was a good week to start back up after my little appendix issue. My FTP is down 25-30 watts, running speed is down 1 mph, swim speed is down, heart rate is up, and endurance is shot. The good news is, I know what I need to do to get back into shape. I know what I’m capable of with the mediocre training schedule i had last year, so with all the hours I’m scheduled to put in this year, I should be back on track in no time. Be sure to keep an eye on my fitness category if you want to know how I’m doing.

My new job at MRT is going very well. It’s nice to be doing a little more programming, especially with Asp.Net MVC on the web side of things. It’s a bit of a change from Terso, what with averaging 1 e-mail/day over the last 3 weeks, and I think I was the first person to schedule a meeting in Outlook. If Terso was small with 20 people, MRT is really small with only 6. Speaking of Terso, if you check out the front page of the Terso Corporate Website, you can see my wife demoing the new Terso TS032 Intelligent Cabinet. I always wanted to be married to a Model ;)

I wanted to put more effort into this post, but since it’s February already, it’s outdated already before I even post it. I hope to make up for this with some additional posts in the near future.

Tuesday, February 02, 2010 3:37:43 AM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
General
# Friday, January 22, 2010

From time to time I have a need for a virtual com port, com port splitter, com port redirector (local and tcp),but most solutions I have found cost too much money. I’ve been able to get by using the named pipes redirection in Hyper-V for some of my projects. Yesterday I came across VSPE by Eterlogic, which offers every feature you could possible need, for FREE! There is a catch though, the 64-bit support costs $24.95, which they say is to cover the cost of the digital signing certificate required to sign their drivers for 64-bit Windows versions. I was able to try the software out on a 32 bit workstation, and it works as advertised. The next time I need something like this, and I’m developing on a 64-bit work station, I will not hesitate to purchase a license, even if it’s just for my home projects.

Friday, January 22, 2010 4:35:32 PM (GMT Standard Time, UTC+00:00)  #    Comments [1] -
Tools
# Wednesday, January 20, 2010

I’m doing a little shopping for a virtual dedicated or cloud hosting provider. I need RDP access to install what ever I need, so Azure is out for the time being. The Amazon pricing page and model was giving me a headache, but after taking a break and coming back, I figured out the correct order to click thru the various information screens and have figured it out. Bandwidth, storage and performance needs are also quite small for the time being, but I wouldn’t consider running with anything less then 2GB of ram for Server 2008, and 2 virtual CPUs is nice.

Minimum Feature Set:

  • 2GB ram
  • RDP connection
  Amazon CrystalTech GoGrid MaximumASP OrcsWeb #1 OrcsWeb  #2
Plan Name 1 Small 24/7 Hyper-V VPS Small Biz MaxV Plan B B C
Total Monthly Price 97.86 $279.95 202.89 $178 $129.99 $179.99
Setup Price $0 $199.95 $0 $0 $0 $0
IP Addresses 1 2 10 2 1? 1?
VCPU 1 ?? 1 2 1 2
RAM 1.7 2 GB 3 2 GB 2 2
Disk Quota 160 GB 120 GB 60-120 GB 40 GB 60 120
Backups Included $80 + $25 setup Included Included Included Included
Bandwidth 10GB In
10GB Out
2000 GB Free Inbound, $0.29/GB Outbound 200 GB 250 GB 250 GB
Trail       30 Day Free Trial    
Notes     For billing, assume 10GB/mo outbound transfer. Disk quota is based on compute unit   Scott Hanselman uses them  

 

Cloud Computing

Cloud computing is all the rage, but its still in its infancy. As such, features are missing and things are still a little rough around the edges. For true elastic computing, Amazon is the way to go (remember, I was not looking at Azure for this comparison). The reason for this is that you can not stop your instances on GoGrid without deleting them. I’m not even sure if I would consider GoGrid a cloud provider without the ability to stop running instances, they are more like an on-demand virtual dedicated provider. GoGrid does offer some advantages over Amazon. They have free inbound data transfer and hybrid hosting. Hybrid hosting allows you to use their “cloud” offering for your web front end, while you can setup a managed dedicated server with some serious hardware for your backend database.

One downside to both services is that you can’t change the specs of an instance after it is created. Since both services let you create your own images (which you have to pay to store), once you get a base machine setup, you can create an image of it and then create new instances from your own image which would cut down on time to deploy. Hopefully the ability to reconfigure an instance is a feature on the roadmaps for both services. If you are going to be doing anything more then single server setups/testing, I would recommend storing your data on the Amazon ESB or GoGrid’s CloudStorage which offers non-instance persisted storage. GoGrid gives you 10GB free, while for the same space, Amazon would charge $1/month. Remember, the ESB or CloudStorage is where you keep your images as well, so it will fill up fast if you storing Windows Server 2008 Images (which clock in around 10GB).

While for the most part, ram is ram, the compute definitions differ between Amazon and GoGrid. Amazon offers standard and hi-compute units, while GoGrid just offers more virtual cpu’s with the larger instances (more ram). In my pricing comparison, I was using standard compute size instances from Amazon, which are the equivalent of 1.0-1.2 Ghz Opterons or Xeons. On the GoGrid side, they claim that 1 compute = a P4 2.0 Ghz, so there is a bit of a difference there.

If you have a lot of variation in your load, then Amazon will beat out GoGrid just because you don’t have to run around deleting instances, you can just shut them down. If you have a constant known load, then Amazon still beats out GoGrid, as you can take advantage of Amazon Reserved pricing. Reserved pricing requires you to pay a fee up front, but you get lower per hour rates for the duration of the term, 1 or 3 years. However, I like the GoGrid management UI better then the Amazon Control Panel.

Amazon:

  • 2 Small (1.7 GB, 1 compute) Front end web servers
  • 1 Small (1.7 GB, 1 compute) App Server
  • 1 Large (7.5 GB, 2 VCPU @ 2 compute) Database server
  • Load Balancer (Costs extra) + 25 GB of traffic (didn’t increase cost)
  • 25 GB inbound
  • 100 GB outbound
  • Price: $706

Amazon with Reserved

  • Same as above but using their reserved pricing option for a 1 year term. There is a upfront cost of $1538, but I divided by 12 and added to the other monthly fee for comparison
  • Price: 377.67

GoGrid

  • 2 2GB (1 compute) Front end web servers
  • 1 2GB (1 compute) App server
  • 1 4GB (3 compute) Database server
  • Load Balancer (Free)
  • Free Inbound
  • 100GB outbound
  • Price: $652

Conclusion

I’m going to give the Small Instance a try at Amazon, just to see how it works, but will probably end up going with one of the OrcsWeb virtual dedicated servers. For what I currently need, the OrcsWeb provides an economical, and probably more important, simple solution.

Wednesday, January 20, 2010 2:38:00 PM (GMT Standard Time, UTC+00:00)  #    Comments [4] -
Technology
# Saturday, January 16, 2010

This post is part of my PDC09 Conference Notes series. These are my raw notes taken while watching the various session videos from PDC09. Refer to my original post for some conventions I tried to use.

PDC Session Link: Networking and Web Services in Silverlight

This session went over the different ways to expose data to a Silverlight application. Data access requirements for Silverlight was grouped in two ways and presented as the following graphic:

image

Each example fell somewhere on the X/Y axis of the chart above. Resource Centric was explained to be CRUD operations, while operation centric was more behavior driven.

Forms Over Data

The first examples were your typical forms over data applications, which are Resource Centric and follow a Request/Reply model.

If you control, and have direct access to the data, then RIA services was recommended. Aside from a short demo, not a lot of time was spent on RIA services, as there are other presentations that get into the details.

Another option for when you control the data, is to use WCF Data Services, which exposes your data in a RESTFul manner that adheres to the open data protocol (OData). In addition to data you control, services like SharePoint expose the data contained with-in via the open data protocol as well. The advantages to using OData sources over public REST services, is that more is known about the data, so you get a better development experience.

If you are working with a public data store exposed with REST, and it’s not OData, then use the enhanced (for Silverlight 4) ClientHttp library. It has a good programming model, and a lot of the deficiencies in previous versions have been solved. For example there is now support for Basic HTTP Authentication secured with SSL.

2 Way and Streaming

The second group of examples looked at duplex and streaming scenarios. The first example was a chat application which is an operation centric example that has some request/reply elements, but mainly users a duplex model. WCF was the recommend technology to support the duplex model. The included binary encoder provided a 71% performance improvement over the standard text encoder, even over HTTP. Binary has been the default encoder since Silverlight 3, but is only useful when both endpoints are .Net applications.

Duplex itself can be setup in your WCF bindings in one of two ways. For internet scenarios, you will need to use an HTTP binding, which is a polling based duplex model. While not present in the beta that was released at PDC, there are plans to enable HTTP Chunking, which would allow for multiple messages per HTTP request to increase performance. For intranet scenarios, you can use the NetTcp binding for the best performance. Remember, since this is WCF, you code once, and just change your bindings as needed.

Silverlight 4 supports UDP multicast, but it is pretty much an intranet only solution, as your network must be configured to support UDP multicast.

There is a new Silverlight TCP Socket Policy server project template in the online template gallery (accessible in VS 2010). This makes it very easy to setup the policy server to allow cross domain socket calls for your Silverlight application. An enhancement being considered for Silverlight 4 is that if the application has been elevated, then you will not need to worry about policies.

Saturday, January 16, 2010 10:49:01 PM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
Conference Notes | Data Access | Silverlight
# Friday, December 18, 2009

I have been a big fan of log4net for the past several years. It’s a light weight, reliable, open source logging platform. Today I needed to create FileAppender that created a log file that had the current date in ISO 8601 format.

After playing around with various options for the RollingFileAppender, I finally figured out the correct way to accomplish my goal. By adding the type="log4net.Util.PatternString" to the file element in configuration file, you can change the name of the log file at runtime based on properties within log4net. It just so happens, that one of the properties is the current date and time.

Here is my appender that I ended up with:

<appender name="MyAppender" type="log4net.Appender.FileAppender">
            <file type="log4net.Util.PatternString" value="logs\%date{yyyyMMddTHHmmss}.txt" />
            <appendToFile value="true"/>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date %-5level %logger - %message%newline"/>
            </layout>
</appender>

I had just never seen the type attribute in the file element in any of the samples I’ve worked with before, so it took me awhile to figure out the correct search terms to narrow things down. I also found a site that makes it a lot easier to search the user mailing list: http://old.nabble.com/Log4net---Users-f154.html

Friday, December 18, 2009 4:44:01 PM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
Programming
# Friday, December 04, 2009

Yesterday I gave my first public group presentation to the Madison .Net Users Group on SharePoint 2010. Even though I was working on the demos up until the time I left my house for the meeting, I still managed to do ok. The speaker evaluation ratings were mostly 4 or 5’s, but I would have had to been pretty bad to get anything lower.

I did get one comment, and that was that I let my voice trail off, and I remember doing this. I tend to think out loud, so that’s probably what this was. However, for a presentation, talking to one’s self looks kind of goofy, and would be even worse if I was mic’d up. So I need to work on this and make sure that I am either speaking to the group, or not at all.

What Worked

  • Writing out everything I wanted to say, word for word on the notes, which I know that you are not supposed to do (read from notes). This ended up working because I was able to recall most of what I wrote down without looking at the notes. I think that I will continue to try to write out what I want to say as a one more way of practicing for the presentation.
  • Overall length of the presentation was good
  • Demo to Slide mix was ok for this topic even though it was slide heavy. There was a lot of information to convey, and I felt that the audience was mostly new to SharePoint that they would appreciate a solid foundation
  • Demo’s worked out pretty well. I may want to consider adding more code comments to help explain things, as well as help me remember talking points

What Didn’t Work (or what do I need to do next time)

  • Number one on my list is don’t procrastinate. I need to allow myself enough time to run thru the presentation at least once.
  • Create some index cards that contain key information that I want to make sure I cover. This would have been useful on a couple of the slides were there was a lot of information to cover.
  • Make sure if you need to read something, that it’s readable in low light situations
  • Don’t re-use step by step hands on lab notes with pictures. Demo notes should be on a single page, unless you need to copy code.

Client Object Model

There were a couple of questions on the Client Object model, and I wasn’t able to answer them as well as I wanted to. So I did a little research and came up with a key points.

The Client Object Model provides a subset of the server object model functionally, which is exposed via a WCF web service. This is intended as  a replacement for custom wrappers around the asmx web services that have been available in the past. The client object model is unified across JaveScript, .Net CLR, and the SilverLight CRL, so if you learn it for one platform, you can re-use that knowledge on the other supported platforms.

The object model was designed in a way to encourage efficient network utilization thru the use of batching. As a developer, you add a series of commands to the context, invoke the cotnext’s ExecuteQuery method, and receive a set of batch results back from the service in JSON. Most of the details are handled for you by the object model, so it’s not like you have to worry about parsing JSON.

Links

Here are all of the links I used for my demo. And as an added bonus, I have included links to all of the SharePoint 2010 videos from PDC 2009. I only wish I would have had the time to watch them all before giving my presentation.

My Power Point Presentation

SharePoint Foundation (Server) 2010

Extra Stuff needed to Install SharePoint 2010 Beta

SharePoint 2007 – WSS 3.0 (Some of these resources still apply to 2010)

SharePoint PDC Videos

Friday, December 04, 2009 4:16:30 AM (GMT Standard Time, UTC+00:00)  #    Comments [1] -
SharePoint
# Wednesday, December 02, 2009

Tomorrow night I am presenting at the Madison .Net Users group. Tonight, I am pulling my hair out, trying to get my demos to work. How far am I? Well I’m on my second demo, but the first one involves 0 programming, so I don’t think that counts.

What is was getting in my way, was a nasty System.Data.Services.Client.DataServiceRequestException, complaining of an invalid DateTime value…somewhere.

System.Data.Services.Client.DataServiceRequestException was unhandled
  Message=An error occurred while processing this request.
  Source=Microsoft.Data.Services.Client
  StackTrace:
       at System.Data.Services.Client.DataServiceContext.SaveResult.HandleBatchResponse()
       at System.Data.Services.Client.DataServiceContext.SaveResult.EndRequest()
       at System.Data.Services.Client.DataServiceContext.SaveChanges(SaveChangesOptions options)
       at System.Data.Services.Client.DataServiceContext.SaveChanges()
       at Demo1.Program.AddEmployees() in C:\_Files\Projects\Demo1\Demo1Completed\Demo1Completed\Program.cs:line 48
       at Demo1.Program.Main(String[] args) in C:\_Files\Projects\Demo1\Demo1Completed\Demo1Completed\Program.cs:line 19
       at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
       at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
       at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
       at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean ignoreSyncCtx)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
       at System.Threading.ThreadHelper.ThreadStart()
  InnerException: System.Data.Services.Client.DataServiceClientException
       Message=<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<error xmlns="
http://schemas.microsoft.com/ado/2007/08/dataservices/metadata">
  <code></code>
  <message xml:lang="en-US">Error reading syndication item: 'Error in line 5 position 14. An error was encountered when parsing a DateTime value in the XML.'.</message>
</error>
       Source=Microsoft.Data.Services.Client
       StatusCode=400
       StackTrace:
            at System.Data.Services.Client.DataServiceContext.SaveResult.<HandleBatchResponse>d__20.MoveNext()
       InnerException:

After installing Fiddler so I could analyze the post and it’s subsequent response, I tried setting the Modified and Created properties on the Entity to DateTime.Now to give them an actual value. The Modified and Created properties are on all SharePoint list objects. I hadn’t bothered setting them, because they were of type DateTime? and I assumed that SharePoint would set them. As a matter of fact, I watched a PDC session on this very topic and blogged about it. In the demo, the only thing Pablo set was the name and the job title and posted it via CURL, and it worked.

I tried setting the values to null, but I got the same error (and why wouldn’t I). I ended up setting the values to DateTime.Min value. This allows the POST operation to succeed, and the Created and Modified values are correctly set by SharePoint.

Other notes of interest:

  • Even though I installed VS 2010 with .Net 4.0, I still had to install the Ado.Net Data services 1.5 CTP2 for SharePoint 2010 to expose data via ListData.svc
  • When building an application in VS 2010 with the .Net 4.0, System.Data.Services.Client is added for you when you add a Service Reference. You do not need to add a reference to Microsoft.Data.Services.Client in the CTP 2.
  • Be sure to check out the different SaveChangesOptions available when you call SaveChanges for your service. The batch option really speeds things up, but if one update fails, they all fail.
Wednesday, December 02, 2009 4:36:17 AM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
Data Access | Programming | SharePoint
# Sunday, November 29, 2009

This post is part of my PDC09 Conference Notes series. These are my raw notes taken while watching the various session videos from PDC09. Refer to my original post for some conventions I tried to use.

PDC Session Link: Advanced WPF Application Performance Tuning and Analysis

This presentation was how you can analyze and tune your WPF applications in 4 key areas: Memory Usage, Cold Startup Time, Warm Startup Time, and Runtime. There were several tools used through out the presentation, and the demos were very well done. I would recommend watching this session to get a better feel for the concepts. The sample application used for the session is called Fishbowl, and is a WPF application that lets you work with Facebook in new ways.

Introduction

  • Measure early and measure often
  • Be sure to test on older hardware
  • Grab low hanging fruit
  • Understand perceived performance (i.e. keep the UI responsive during long running requests)
  • Trade Offs
    • CPU vs. Memory vs. Disk IO
    • Within your application, you may have to pick and choose which features are faster then others

Memory Usage

  • 150MB of memory was deemed as high for an application like Fishbowl
    • I found this to be very surprising given how many seemingly simple WPF apps I have seen using over 200mb of memory at startup. Is memory cheap these days? Yes, unless you count limited memory on Netbooks, older computers, and virtual machines.
  • Process Explorer to view overall memory usage
  • Sys-internals VMap to view detailed memory usage by process
    • Image: .exe, .dll, etc
    • Heap: Pure managed applications should have lower native heap then managed heap. You will always have some native heap, as some CLR stuff uses native memory, like the render thread. Images (pictures) are also stored in the native heap and are one source of high native heap usage.
    • Managed:
  • The cause of the high memory usage was the use of 114 images for the startup animation.
    • # of images * width in pixles * hieght in pixles * 4 (32 bit color) = memory usage
    • 114 * 272 * 294 * 4 = 34.7MB
    • The actual cause turned out to be that the start view was not being disposed after it was finished, so the images remained in memory.
  • SaciTech Memory Profiler on memProfiler.com
    • Costs money
    • WPF perf team uses this tool internally
    • Lets you do snapshots so you can compare memory usage over time
    • You can drill down by object type, as well as what is holding onto the reference for a particular object.
  • Element count (virtualization) is another pain point

Cold Start

  • Cold start is impacting most by Disk IO
  • Windows Performance Tool Kit or Windows SDK?
    • xperf command line tool (there is a PDC session on xpef and ETW)
    • Event Tracing for windows (ETW): Add ETW statements to your app and profile with xperf
    • Demo showed a batch file to start up xperf
    • Look for for highest number of reads
  • Remove unneeded dll references
    • System.Windows.Forms and System.Windows.Drawing shouldn’t be needed in pure WPF application
  • If you are using only one or two methods from a dll, you could merge it into your application
    • You can use Scitech Mem Profiler to see how many types for dll to see you can eliminate or merge
  • If you are using a managed API that is dealing with win32 api’s, you could add p/Inovke’s to your code to eliminate an extra dll.
  • Be sure to test in release mode with no debuggers attached
  • You can use NGen to speed up cold start, but it might slow down warm start

Warm Start

  • Warm Start is CPU bound, so you will see high CPU usage. There should also be lower disk IO then cold start.
  • If you see low CPU usage, there might be something blocking, like network access (using xperf again)
  • CPU Profiler
    • Comes with Team Suite
  • WPF Perf
    • Part of Windows Performance tool kit
    • Check item count, is virtualization enabled. Sometimes virtualization can’t be used, like when list element height is dynamic, which would screw up the scroll bar

Runtime

  • More WPF Perf usage
  • Trouble shoot jerky animations
    • Layout vs. Rendering
  • Pererator Tool:
    • Review hardware IRT’s. In the example, 20 hardware IRTs was too high.
  • Problem was traced to drop shadow animation. Solution was to create two elements, one with and one without drop shadow, then toggle visibility
  • Other stuff
    • Don’t block on the UI thread
    • Virtualization when needed
    • Freeze your freezables
      • No change notification call backs
    • Hardware vs. Software
      • use RenderCapabilities.Tier to determine when you should dial down visual effects.
Sunday, November 29, 2009 4:36:28 AM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
Conference Notes | WPF

This post is part of my PDC09 Conference Notes series. These are my raw notes taken while watching the various session videos from PDC09. Refer to my original post for some conventions I tried to use.

PDC Link: Advanced Topics for Building Large-Scale Applications with Microsoft Silverlight
Presenter: John Papa (@john_papa)

The title of this presentation is a little misleading. It could have just as easily been titled, best practices for building line of business applications in SilverLight. The concepts, if not most of the code can be applied to WPF as well. There was a lot of talk about Prism, which I have not looked at in great detail. However, as a result of this presentation, I will take a closer look at it once I get around to working with SilverLight and WPF more. John pointed out several times that you are able to pick and choose what parts of Prism you want to use, which at least makes it sound a little less invasive then some of the other things to come out of Patterns and Practice.

A similar framework which is not developed by Microsoft is Caliburn. Which one is better, is probably open to debate, and both are continued to be developed. John did mention some gaps in Prism, which he developed some code for (posted via his blog), but perhaps these are available in Caliburn. If you are just starting out with SilverLight or WPF, I would suggest looking at both frameworks. If you are already using one or the other, I don’t know how much sense it would make to switch, but I always like to keep my options open.

MVVM

The first part of the presentation was focused on defining MVVM, or the Model, View, View-Model pattern. The primary benefit of the MVVM pattern, is that is allows for good separation of concerns, which leads to increased testability and maintainability. As you can see below, a lot of time was spent on describing the View-Model and how it fits in, while the View and Model are fairly straight forward.

  • View: Responsible for rendering the UI only
  • Model: Contains your domain entities (i.e. customer, order and order details)
  • View-Model:
    • Handles the communication between your View and Model thru bindings, commands, events.
    • Responsible for providing everything (data) a particular view requires.
    • Sometimes your View-Model will look almost identical to your model. Other times, it will contain a mash-up of various entities as required by the view.
    • Ensures that your view knows nothing about your model, and that your model doesn’t known anything about the view (or require references to view related dependencies)

Three ways to implement MVVM were presented. I had never considered the first two, while the 3rd one is where frameworks like Prism, Caliburn, Ninject (Inversion of control) come into play.

  • ViewFirst (Static Resource): View Model can be created as a static resource in the view. This tightly couples the View Model to the view, but gives you the best experience when using Blend (referred to as blenability)
  • ViewFirst (Code Behind): The view is injected to the View Model constructor. Since you loose the blendability, I’m not sure why you would pick this over option 3.
  • View + View Model Marrige: Use a intermediary to marry the View and the View-Model together. Again, you loose blendability, but this is the approach that everyone takes when using Prism, Caliburn or a home grown framework.

When creating a SilverLight application using MVVM, there are some common functionality that you need to implement, which is where Prism and Caliburn come into play. Since this session used Prism, I will list what was shown, which was limited to what Prism can offer. I expect that Caliburn offers a similar set of functionality.

  • Shell: Container for all UI modules, such as menus, windows etc.
  • Regions: Shell is made up of regions which control where UI modules are displayed.
  • Modules: Separate code modules that can be developed in isolation and then loaded by Prism. Modules can talk to one another thru event aggregation (I wonder if MEF would be a better choice)
  • Event Aggregation: An eventing model that allows for cross module communication.
  • Commands: SilverLight 4 adds support for commands, so it is my understanding you do not need to use Prism’s command support anymore.
  • Bootstrapper: Controls application startup and configuration. Configure your IoC here.
  • Delegate Command object for use with commands (very simple class to create if you are not using Prism)

Commands:

  • Invoke an event on your view and have your view model respond to it.
  • When you invoke a command, you expect a response.
  • Commands work out of the box well with buttons. However you need to create new command objects that implement ICommand for use with other controls. John puts these objects in his Infrastructure dll, and I think he may have provided some of this code on his blog.
  • I still have a lot to learn on commanding
Sunday, November 29, 2009 3:45:42 AM (GMT Standard Time, UTC+00:00)  #    Comments [0] -
Conference Notes | Silverlight | WPF
Archive
<February 2010>
SunMonTueWedThuFriSat
31123456
78910111213
14151617181920
21222324252627
28123456
78910111213
About the author/Disclaimer

Disclaimer
The opinions expressed herein are my own personal opinions and do not represent my employer's view in any way.

Copyright 2010
Adam Salvo
Sign In
Statistics
Total Posts: 234
This Year: 13
This Month: 1
This Week: 0
Comments: 34
Themes
Pick a theme:
All Content 2010, Adam Salvo
DasBlog theme 'Business' created by Christoph De Baene (delarou)