Slashdot Mirror


Organizing Your Web Services Division?

Anml4ixoye asks: "I currently work for a county government as their senior webmaster. Before that, I oversaw the internet development for a large credit union. In both places I ran into the same issues. What should compose a web services team, and where does it belong within an organization? I notice that larger companies such as IBM have separate departments for their web sites (VP of Web Site Operations). So my question is, should the team that handles the organization's web site be its own entity, being solely responsible for the hardware, programming and implementation of the web site, or can those tasks be effectively split between several sections and still work? Can anyone give some insight into how it works within your organization?"

"For example, at the credit union, the position I was hired into was brand new. They wanted to bring their web site in house. Their solution was to hire a Manager of Internet Development (me) who was responsible for determining the needs of the credit union, setting up the servers, doing the development and programming, and maintaining the site. No staff, and they wanted the site up as quickly as possible. I spent most of my time reporting back and forth between the VP of marketing and the Director of IT. When they finally figured that wasn't going to work and tried to have me report to one department, they couldn't figure out which one it should be so they eliminated the position and outsourced the web site again.

I am running into the same thing at the county. I came on about a year ago to a web site in shambles. The previous 'web team' consisted of an Internet Administrator, a team leader, a webmaster, a web data specialist, and a web temp. The team leader wanted them to be their own section, but unfortunately, he did it by power-playing and burning bridges. The Director of IT came through and broke the team apart, firing the team leader and the web data specialist, releasing the temp, and splitting the remaining team between the Distributed Processing Management (DPM) and the Network Administration sections. The other webmaster left about two months after I came on, leaving me as the sole webmaster for 3 sites of around 80-100 thousand webpages. We are finally back up to staff (another webmaster and a web-data specialist). The challenge we are running into is that in order for items to get on the site, they are designed by the departments, approved through our communications department, then passed on to us to integrate into the site. If we have a server problem, we have to contact Network Administration, even if it is something like having a Data Source Name set up.

To further challenge matters, the manager we report to has 28 people who directly report to him, including us.

With the size of the sites being what they are, it wouldn't take much for the whole thing to fall apart, and I am trying desperately to prevent that from happening. I envision an Information Architecture being put into place which would allow us to work on content management, instead of building these pages by hand. But I seem to run into obstacles every where I turn."

15 of 98 comments (clear)

  1. Like I'll tell... by Anonymous Coward · · Score: 0, Insightful

    Isn't this why you get paid?

    I mean come on! If you're not competent enough to do your job, why should anyone here tell you?

    Oh, and by the way, FP beeyatch.

  2. Process & boundaries are key by Hoonis · · Score: 2, Insightful

    If you are working at a startup, you can do it all
    yourself (hardware, design, code, maintenance, etc).

    The age-old conflict is the IT people want it
    maintainable, always up, and conservatively
    designed, marketing wants to do things on the
    seat of their pants without advance notice..

    I separate the server maintenance from the updates. I manage a colo, server, backups, and the cgi parts of the server, the contractor of the week does the design & updates. The tools I have built are all designed to have no ongoing maintenance from me (IT reporting).

    If you can make that clear from the outset,
    you can co-exist well with a marketing department
    or a PR branch etc that needs an effective
    publishing platform. These boundaries sometimes
    result in conflict:

    Do it quick
    Do it stable/well

    but rarely does it become catastrophic if you
    work with good people.

  3. Separate design, coding, and administration by revscat · · Score: 5, Insightful

    The best models I have seen have different groups responsible for the design, the coding, and the hardware. The design people are usually the freaky Mac types, the administrative people are the moles who are really into that kind of thing, and the software people are the attractive psychologically balanced ones who do the actual work.

    Ahem. Excuse me.

    Seriously, the separation of labor between these three camps works out best because it allows each group to maximize their specialty. If you have some designers with good HTML skills, then your coders can, for example, just drop in, custom JSP tags where appropriate without having to mess with the web server or design principles. A group consisting of people who have a lot of knowledge in one of these areas and a little knowledge in each of the other two tend to perform best. I hate to use the word "synergy" but it really is appropriate here.

    Depending on your resources there are other areas to consider as well. Q&A is extremely important and can help the developers to more efficiently debug. Content writers and proofreaders are important as well; someone who can tell the difference between "your" and "you're" can be a real boon to your professionalism.

    But the basic web team, IMHO, should minimally consist of the three core elements I listed above. The most successful projects I have worked on have been variotions on this theme.

    - Rev.
  4. Make content owneers work for you by Infonaut · · Score: 3, Insightful
    The government agency I used to work at hired me as their first official webmaster. I was placed in the Public Affairs office, but I also reported directly to the Chief of Staff. Of course, in order to effectively manage content, I had to take information from several different departments, all with their own agendas. Prioritizing whose content would go up where and when became a nightmare.

    So I decided to change things around. I formed a committee (yes, an evil committee, but bear with me). The members were mid-level people from each of the dozen or so internal constituencies. We met twice a month to review the direction of the site. They would inform me if something I was doing bothered them, or if they wanted something new added.

    I would also meet individually with these members, and we'd prioritize the content for their department. I'd then collect all of the content "wish lists" together into one master list. The committee members could then see the entire list, and see where their items were on the list. I'd have the Chief of Staff review the list as well, and since they knew he'd signed of on it, they couldn't hassle me when a priority of theirs wasn't high on the list.

    The best thing was that these mid-level people were the sole content managers within their departments. All content for that section of the site had to go through them, and then on to me. If they slacked off on the job, or didn't help me out enough, I could talk to their supervisor about it. If they did a good job, they got kudos from the boss, if they screwed up, everyone in that department knew why their part of the site was lagging.

    It wasn't a perfect solution, and it can't be applied in every organization, but it helped me maintain my sanity as the sole person developing and maintaining a 1,200+ page site. Even though I left three years ago, the structure I put in place is still being used, and the site has more than doubled in size.

    The key to it all is that you have to try and understand human nature. Everyone wants to sharpshoot you if you fail, but by setting up a system that puts other people in the loop while still giving you primary control over development, you can keep your sanity, and more importantly, build a system that will work for everyone.

    Best of luck - I feel your pain.

    --
    Read the EFF's Fair Use FAQ
  5. Re:public websites by rjamestaylor · · Score: 2, Insightful

    Choice of technology has no bearing on this question. Or did you know that and just decided to troll?

    --
    -- @rjamestaylor on Ello
  6. Tips From the Big Guys: by corky6921 · · Score: 4, Insightful

    I work for a large company doing web development for the external site. There are several problems with our website. Since our group (Internet Engineering) is in charge of future development for the site, we've charted out the problems and their solutions. Here is a short synopsis:

    • Content management system. It's crucial when doing a large website. Ours is horribly outdated. Keys to a good content management system: it should be web-based, and it should be a standard, out-of-the-box solution with as little customization as possible. It should allow for maximum flexibility. (We've run into problems with ours not supporting custom META tags, for instance.)
    • Don't let IT run your website unless you know all of IT personally. In a large company, unless you have a dedicated (and by that I mean reporting to the same VP as your core web team) IT department, you're asking for it. If I told you what IT refuses to do to our website, you'd be shocked. For instance, we only support {ancient scripting language}. We were supposed to have other scripting languages supported this year, but that hasn't happened. Our department is slowly absorbing IT's functions so we can crank things out faster. Meanwhile, we continue to get last priority with IT, and we don't have the root passwords to our own servers. (In recent months, they have given us tools to check log files, but that was two years in the making.)
    • Follow IBM's rule. You mentioned IBM's web services division. In fact, IBM is the standard by which most other e-commerce sites should be judged as far as organizational hierarchy. IBM did a presentation earlier this year about their web site; basically a "tell-all". Several other high-profile companies attended. Someone asked an IBM person why they did the informational session; the reply was "We're so far ahead of everyone else; we don't think anyone can catch up." Key point to IBM's success: totally separating nearly EVERYONE who develops for the web site under the same department. If you have someone in each department doing the website, you're going to get a website that defines subsections by the organization's departments, some of which may be mumbo-jumbo to outsiders. For instance, "Information Services". What is that? Separating products into categories like "Software" and "Desktop Systems" is much more meaningful, but this can only happen if you have one group in charge of the web site. Otherwise, the tendency is to title subsections by the department name, which results in some weird naming conventions.

    Where I work is not important; what's important is what you can learn from our mistakes. Every major company has organizational problems with their web site. Your company must take these issues and deal with them now as opposed to later. A content management system is an invaluable tool in helping with these issues. Most feature workflow routing so you can have one manager signing off on several people's projects before they get published. You can then also hire graphic designers without having to hire a complementary Dreamweaver jockey; good systems create HTML and correct menus for you in a lot of cases. Most take the Developers / Graphic Designers / Managers / Administrators approach, where they place you in one group and you get different tasks according to what group you're in. This may or may not work for you; the good thing is that in a good content management system, you can customize it to fit your needs.

    It's great that you've asked this question when your group is still small. It shows a lot of forethought that the older, larger companies didn't have time for. In a lot of respects, you're lucky: you can design an ideal system. Just make sure it will scale and that you can easily upgrade if some new time-saving feature comes out in a year or two.

    1. Re:Tips From the Big Guys: by marxmarv · · Score: 3, Insightful
      Content management system. It's crucial when doing a large website. Ours is horribly outdated. Keys to a good content management system: it should be web-based, and it should be a standard, out-of-the-box solution with as little customization as possible. It should allow for maximum flexibility. (We've run into problems with ours not supporting custom META tags, for instance.)
      "Content management system" is a glorified name for "source control software" with prettier buttons and a heftier price tag. Whatever you do, do NOT spend more than $20k on your content management system. If you do, you could have just as well paid a monkey to hack CVS for a month and come out the other side with something much nicer, cleaner, and more customizable. Web interfaces are not essential; a GUI client is very nice to have for the content producers. Customization is not evil when offset by documentation; make sure the latter gets done, all the time, every time.

      If I told you what IT refuses to do to our website, you'd be shocked.
      It's easy to shock Linux fetishists with supposed wrongs when you've never administered a production site for yourself. If I told you what development at a recent job has done to our systems, you'd be embarrassed. Let's see... NFS was used for all inter-machine communication because apparently none of them could be bothered to write socket code. A single machine served NFS requests for "site_status" because eng couldn't be bothered to write socket code; the ramifications to the stability of the site were Not Their Problem. Developers controlled the configuration files; adding a machine to the web farm involved haggling with them. Worse still, they hardcoded web farm machine names into the code to make exceptions rather than use proper configuration files or documentation. They controlled portions of the health and monitoring system, which became a messy accretion of sad, broken, unreliable tools. These were all people with over ten years of experience in software engineering, supposedly.
      Meanwhile, we continue to get last priority with IT, and we don't have the root passwords to our own servers.
      Damned right you don't. Developers don't get access to production, ever. If a developer needs access to production, then they are fixing a problem irreproducible in the test environment. At no other time does a developer need to even touch production -- that's what test harnesses and environments are for. If you haven't even got a separate pre-production test environment, then pretty much nothing you have to say is of any value at all.

      Applications should never run as root. If you think you need root access to listen on port 80, what you really need is to run your web server on high ports and make the load balancer or other firewall translate the request. If you think you need root access to modify certain system files, you really need to not use that part of the system. If it takes two years to get access to logs, then maybe your operations people are trying to tell you to stop shitting on them.

      If you have someone in each department doing the website, you're going to get a website that defines subsections by the organization's departments, some of which may be mumbo-jumbo to outsiders.
      Which is why you have an editor or relatively small editing committee that makes final decisions about every color, every menu, every word, every URL that gets published.
      You can then also hire graphic designers without having to hire a complementary Dreamweaver jockey; good systems create HTML and correct menus for you in a lot of cases.
      When you give powerful tools to people who have no idea what the consequences of using them are, you get a web site that impresses only managers. So your content management system creates menus and HTML for you? Is it compatible HTML? Does it work on all browsers? With or without Javascript enabled? (It's hard enough for Dreamweaver jockeys to get that last one right.) If your copy people can't hand-code HTML when necessary and understand every single detail of any HTML that's automatically generated, they're not qualified for the job, especially in this market.

      the good thing is that in a good content management system, you can customize it to fit your needs.
      What happened to "as little customization as possible"? Heh.

      Why don't you identify your success story of a site? The Keynote numbers can tell us whether your lessons make for a better, more reliable site, or whether you just talk a good game.

      -jhp

      --
      /. -- the Free Republic of technology.
  7. Ideal Web Team by Andrew+Wiles · · Score: 4, Insightful

    Yeah, it makes sense to have a single group in charge of the company Web site. This eliminates duplication of effort and -- more importantly -- makes sure your whole site has uniform navigation and graphics so that users don't give up in disgust. Stuff like a single sign-on is also important for huge sites.

    For a medium-sized site, the team should consist of:

    • One person who can spel
    • One person who can coordinate colors
    • One person who knows how to reboot NT (or edit an .htaccess file), install patches, and who handles stress by kicking ass
    • One attractive, well-adjusted coder
    • One trained (web)monkey who can take copy and pictures from 3 million incompatible sources (i.e. your marketing and sales departments) and turn it into web pages

    It doesn't have to be exactly 5 people, but some number of people who combine to cover all these skills.

    Oh, yeah, I forgot a really important one:

    • One person with good tech vision who can make sure the other guys don't make things too hard for themselves. This is the person who makes sure the system everyone uses for plugging the content in doesn't get too complicated, that the programmer doesn't spend 80 hours trying to implement those dumb Javascript menus desired by Marketing, etc. This person is also the hard-nosed schedule Nazi who is responsible for Getting Things Done. He or she has to have a tech background, and must be able to communicate with the suits.

    This last person isn't necessarily more important than the others, but he/she is harder to find. Lots of projects fail for lack of this guy, the one who tells the other suits "That would be too expensive," and "That would take too long," who sets expectations so that when you (the programmer) have done a damn fine job, the rest of the company knows it.

    If you haven't been in industry yet, you have no idea how important that is.

    --
    Andrew Wiles
    a**n + b**n != c**n for n > 2
  8. Organization by Anonymous Coward · · Score: 1, Insightful

    After taking my licks in this industry for a decade, I think I've learned some hard lessons about management:

    1. You need a person who makes the decisions. PERIOD. Anyone who tries to bring issues above his/her head should be slapped down by his/her seniors.

    2. This figure needs to diligently listen to the needs of his organization. However, this figure also needs to resolve conflicts quickly and decisively. If this means hurting someone's feelings, hurt them (and maybe sweet talk them later). If this means firing someone's sorry ass, fire them.

    3. Experience and "the right way" takes priority over personal feelings and political correctness. Encourage controlled conflict. Stir things up at designated meetings. And if any level of yelling or bad feeling arises, there should be a mandatory drink-beer-and-talk-shit after work.

    This is how things get done.

  9. This Guy Is Full of Bullshit!!!! by Anonymous Coward · · Score: 1, Insightful
    Honestly, the moderators are just completely clueless. Do they mod up posts that only sound good?

    I honestly doubt that "Walter Bell", a systems engineer at NASA would have time to post so much on slashdot.

    I work for a government contractor, and have seen government systems, the idea that they would tinker on niche OSs is completely laughable. They are usually the LAST people to move to the latest platforms. The computer technology used by gov't is hardly cutting edge.

    So while this guy might have a web server with HURD running, it definitely is not commmon to see.

  10. IT vs Web team deathmatch by swb · · Score: 3, Insightful

    Heh, I've seen (participated in?) the IT vs. Web development wars and it's not a good idea to have Web as a client of IT because IT is usually pissed/jealous/scared/disgusted at/of/at the Web group for many of the same reasons that the Web group can't stand IT.

    I was on the IT side, and we had a shitpile of varied systems and thousands of end user computers to keep running *securely* and in whatever harmony the software would allow, within our budget, and within the complex politics that is most corporations. A complicated job by itself.

    The web people I worked with were usually nice, I even respected some of them. But they didn't get the big picture of the total environment as well as we (tried to) do, and they were always at the bleeding edge of everything and were pissed because we wouldn't do massive client-side upgrades every time there was a .001 rev of some plugin or why we woudln't run machines with no security, hand out root passwords, etc.

    I'd agree with you that they need to be seperate, in fact I'd vote for totally seperate -- like in another building across town. I think better web sites (better interop, better functionality, etc) comes from not even dreaming about having any influence or control over the desktop environment.

  11. Don't ask, Don't tell my friend by thecrusher · · Score: 3, Insightful

    If you have a VP who is so stupid he/she can't figure out this stuff for you then you are going to have an impossible challenge. The problem is that if you take some of the advice I have seen on this thread (create your own well thought out plan and present it blah blah) which are great ideas you run the serious risk of becoming the enemy of the VP who realizing they are failing horribly will start to attack people below them. Its human nature. So screw trying to teach this idiot what they should already know and would either only take credit for or sabotage. If the CEO/president of your company is so lame they can't hire the right people which really is about the most important part of their job then I say colelct your checks, keep quite, and leave ASAP. And of course warn the rest of us who these idiots are so we can avoid working for them or demand outragous salaries for taking on the stress of leading from the bottom. All that talking will do (if upper management doesn't see the problem already) is get you into trouble. -m

  12. Well THIS is a fun question! by Anthony+Boyd · · Score: 4, Insightful

    First off, let me say that of all the responses, you need to be listening to corky's response the most. Having worked on some huge sites myself, I can confirm that he appears to actually speak from experience. As for my experience, I've worked at 4 companies since I got into the Web in 1994. Here's the breakdown:

    • At Borland in 95-98, the Web stuff was part of "Electronic Marketing" which was an offshoot of the Marketing group. IT ran the Unix servers, but I and 2 others built most of the apps as part of the Marketing team. IT eventually tried to deploy StoryServer for content management, but it was terribly inflexible at the time. Since I had been building highly creative, DHTML games and presentations to hype product launches, I couldn't resign myself to a future of paint-by-numbers page building. I bailed.
    • At Actuate in 98-00, I was the sole Web person for most of the time. I was in Marketing. It was flat-out miserable trying to convince the VP we should be using Oracle instead of Access or MS SQL Server. I was forced to use technology based upon who we partnered with rather than upon what was superior. When I left, the CEO offered to move my "team" into its own department, reporting directly to him. I should have listened to him. He was right.
    • Arzoo was a Web company, so I was part of the design team. There was no IT or Marketing, not in any substantial sense. There were a few product marketing people, and they mostly used my team to create content.
    • At SST, I am currently part of the IT department, and I run a small team called "Web Technology". This seems to be the best balance for me now. I have a lot of Marketing under my belt, so being in IT has allowed me to build a technically competent team but I focus them on the company's image, helping Sales, and so on.

    In my experience, the best solution is autonomy. Being in Marketing, you are going to butt up against people who are driving technology decisions but have no clue what they're talking about. Marketing people should not be managing developers. In IT, the Web will either be too rigidly controlled, or will be a hodge-podge of all the various new technologies the geeks wanted to play with.

    At SST, the saving grace has been the content management system, which we've built entirely ourselves. It's simply a few Web forms that dump data into a database. And then other Web pages use that data for display. But what is sooooo important is that each form has an owner, and that person is responsible for filling it out when needed. Each time we deploy a form, we free IT from the manual labor of building and rebuilding pages upon request. We are also able to tie in automated signoffs -- some content goes to a manager for approval, some content is published immediately. Whatever the case, you need a content management system. A small, nimble one.

  13. Re:Committees by j-jahnke · · Score: 3, Insightful

    Apparently you have never worked for gubbiment at any level, committees are how things are done, consensus. Isn't the always the best way to get things done, but remember the person who you must please most got his/her job in an election. As such they MUST have some input. Universities work this way as well, but becuase faculty contribute to departments via outside funding.

    So having said that, when I was tangentially involved in a similar fiasco, the reporting went like thus. The actual nuts and bolts of the operation went via IT. The programmars and machine administration was done via IT content specialists were in Marketing (actually they were departmental admins, but liked it when we told them they were Marketers.)

    We had a template all departments were supposed to conform to, none of them liked it, but the template had it's own process which was a big ass committee and was updated on average every 9 months. This way if there were complaints about how the template looked there was a committee to redress it, and we had a stable spec from which to operate. It also effectively lets you turn away requests to do one offs, which are time wasters, you can just point to the spec and point out that what user XYZ wants can't currently be done and to bring it up at the next template meeting.

    The IT guys were responsible for maintaining the template, keeping it consistant with what the template committee wanted (if you wanna hear boring some of those meetings were real dooozies, arguments bout font size and exactly how things should be named, as well as what EXACT colors should be used for what banners.) Anyway becuase we used a templated approach the content folks just opened up the editor which was online and inserted the data they needed. When the template was changed they did not have to reenter data it was just plugged into the template.

    By doing this we put a clear line of seperation between what was content and what was IT and no one ever got too bent out of shape about it. But like I said what helped the most is that what things looked like was defined from the start and it was then our responsibility as IT to provide both the tools and server support for the content people, they could do it if they wanted but 9 times out of 10 they just came down with drawings and floppy discs and let one of our own interns plug it all in.
    IT was happy becuase my programmers had a well defined set of tasks to work on, not an ever growing long list of one offs that had to be done for X, Y or Z. We did have a lot of push back when we moved from departments doing their own thing and moving into the template so we used a carrot and stick approach. We told them we would take their current system and convert it to the template form. We would then tell them once converted we would no longer support their old web infrastructure. If it was on our machines we turned it off, if it was on their we never came to fix the problems.

    The deparments liked it becuase they could participate in what the template looked like and we did most of the work. They had a set of tools which let them modify the data whenever they wanted.

    In all I have been gone a few years the process is still in place no one loves it but it has not devolved into pure chaos again either.

    Jer,

  14. The Wrong Way by TheInternet · · Score: 3, Insightful

    A company that has its web team reporting to marketing just screams "we don't under the internet." Marketing executives simply don't tend to have sufficient experience with engineering and administration issues to understand the goals, challenges and advantages of having a web site.

    A lot of companies see their web site primarily as a marketing tool. That may be, but running a web site is completely different than laying out a catalogue or brochure.

    - Scott

    --
    Scott Stevenson
    Tree House Ideas