Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
BT

Facilitating the Spread of Knowledge and Innovation in Professional Software Development

Write for InfoQ

Topics

Choose your language

InfoQ Homepage Podcasts Building Green Software with Anne Currie and Sara Bergman

Building Green Software with Anne Currie and Sara Bergman

What Does It Mean to Be Green in IT? That's the question that begins chapter one in Building Green Software. In this episode, Thomas Betts is joined by two of the book's authors, Anne Currie and Sara Bergman. The discussion covers general themes and digs into some practical advice for all software practitioners.

Key Takeaways

  • Green software is optimized to run on renewable energy sources, is more energy efficient, and/or is able to shift work to when renewable power is available.
  • Key principles of green software include energy efficiency, hardware efficiency, and carbon awareness.
  • Although cloud usage costs are a proxy for measuring efficiency, it can be a very useful proxy. In general, green software is cheaper than less efficient software.
  • AI/ML and large language models need to be architected with sustainability in mind. Where possible, use smaller, specialized models, and deploy them closer to the edge.
  • The Green Software Maturity Matrix provides a framework for organizations to incrementally improve the sustainability of their software.

Transcript

Thomas Betts: What does it mean to be green in IT? That's the question that begins chapter one in Building Green Software. Today I'm joined by two of the book's authors. Anne Currie has been a passionate leader in green tech for many years. She's a community co-chair of the Green Software Foundation, as well as lead of the GSF's Green Software Maturity Matrix Project. Sara Bergman is a senior software engineer at Microsoft. She's an advocate for green software practices at Microsoft and externally. She's an individual contributor of the Green Software Foundation. Unfortunately, their co-author, Sarah Hsu was unable to join us today, Anne and Sara, welcome to The InfoQ Podcast.

Anne Currie: Thank you very much for having us.

Sara Bergman: Thank you for having us. Excited to be here.

Thomas Betts: I guess I should say welcome back Anne. You've been on before, but it's been three or four years probably. You talked with Wes and Charles in the past, so welcome back.

What does it mean to be green in IT? [01:10]

Thomas Betts: So, let's start with that opening question from your book: what does it mean to be green in IT? Anne, you want to start?

Anne Currie: It's an interesting question. What does it mean to be green in IT? The O'Reilly book came out in April and is going well so far. People generally like it. It gives a good overview of what we'll need to do. The good thing about writing a book is you learn a lot about the subject while you are writing the book. Going into the book, so when we started on chapter one, I think our view of what is green software is software that produced the minimum amount of carbon to operate it. So, without dropping any of the functionality, without dropping any of the SLAs, it's produced less carbon, and that usually means it's more efficient, uses fewer servers to do the job, and/or it runs when the sun's shining or the wind's blowing, so there's more renewable power available.

But I think by the end, my thoughts on it had changed quite a lot. And nowadays I tend to think that green software is software that is optimized to run on renewable power because that is the power of the future. That is the only way we're really going to get green in the future. So, all of those things, being more efficient, being more able to shift and shape work to when the sun is shining or the wind is blowing, it reduces carbon, but it is what is required to run on renewable power. That's a little bit of a confusing answer, so Sara, what do you think?

Sara Bergman: I think it's good... It explains also what our minds went through when we wrote the book, so that's good. Or I don't know, should people have a closer insight to our minds? I don't know if that would be good or confusing, but anyway, no, I agree with your answer. I do think, because we're on a journey, the energy transitions are moving from these fossil fuel, always-on energy sources that have dominated the energy sector, well, they're going away slowly and being replaced by renewables. We aren't quite there yet though, so it still matters. The other things still matters. Energy efficiency matters. It's going to matter less, I dare say, once the energy transition is complete.

Then this shifting capabilities are going to come out in full swing. I also think hardware efficiency is fascinating, so that means doing more with less, so being very mindful of the carbon debt, and that lands in your hand when you get a shiny new device. And there are many ways we can do this, and that people are already doing it.

Fundamental principles of green computing [03:36]

Thomas Betts: I think the two of you hit on a couple different themes, and maybe we should dive into these and explain what the terms mean. So, we talked a little bit about just energy efficiency overall, but also I think, Sara, you mentioned hardware and hardware efficiency, and there's an aspect of carbon awareness that you discuss in the book. So, what are those fundamental principles of green computing?

Energy efficiency [03:57]

Anne Currie: Well, shall I do efficiency and you do hardware efficiency and then we'll both talk a little bit about carbon awareness? There are specialist subjects, so carbon efficiency is about producing the same functionality with fewer watts required, which really means with fewer CPU cycles because CPU is very correlated with energy use in servers. So, a more efficient system does the same stuff for you... well, uses less power to do it. So, that's incredibly useful at times when the sun isn't shining and the wind isn't blowing. When you're running off non-renewables, when you're running off fossil fuels, you want to be using less power to produce the same output. And there are various ways you can do it.

You can do it through operational efficiency, so just being a bit cleverer about the way you use systems so they're not, for example, over-provisioned. And you can also do it through code efficiency, so not running 10 lines of code when one would do. That's a much more controversial and difficult subject. We've got a whole chapter on it in the book, but in addition to that, we've got hardware efficiency.

Hardware efficiency [05:03]

Sara Bergman: Yes, hardware is... In case you haven't thought about it's a very labor-intensive and carbon-intensive thing to produce because minerals are mined all over the world, shipped to other places, assembled sometimes in very energy-intensive ways before they land in your hand or in your server hall or in your closet where you keep servers, I don't know. I don't judge. But it's significant carbon debt, and that's already paid. Once you get it and it's brand new, you've paid the substantial... or the environment's paid a substantial cost for that to happen. So, we want to be mindful of that. One of the best things that we do is to hold onto it for longer, so that we amortize this cost over time and prolong the new additional cost of buying a new shiny thing. And if you are a software person, I do identify as a software person, it's easy to say, "Well, that's not my problem. It sounds like a hardware person's problem".

And they are certainly aware of it, and certainly thinking about it and working on it, but we as software people are not off the hook because the type of software that we run highly impacts the type of hardware that we have. If you just look at any enterprise software today, you could not run it on a machine that's 30 years old, for example, because they are massively improved. So, they kind of lockstep. We get better machines with more complicated software and so forth, so forth. Also on the client side, and now I'm thinking PCs, smartphones, smart TVs, for example, there we see that actually the manufacturing cost in terms of carbon is much higher than the use time. So, it's very, very important to be mindful of that cost. And you can do that in multiple ways and that's a whole chapter in itself, but I think that's the short dish

Anne Currie: Sometimes that carbon that you have to pay out upfront, a lot of the terms in this whole area are very confusing, sometimes it's called embodied carbon, sometimes it's called embedded carbon, but it is basically the same. It's the theoretical amount of carbon that was emitted into the atmosphere when your device was created.

Sara Bergman: And it's basically... I believe it's a borrowed expression. It comes from the building industry. They use the same terminology.

Anne Currie: I didn't realize that. That's good. And one of the things that's quite interesting is in the tech industry, when you're talking about consumer devices like phones, it's all embodied carbon. That's a major issue. Huge issue with embodied carbon in phones and user devices, but in data centers, embodied carbon is not the main problem in data centers because the hardware data center is really well managed compared to how you manage your devices at home. You don't keep them as highly utilized. You don't keep them as long. In data centers, it's mostly about the electricity used to power your servers, how that was generated. That's the biggest cause of carbon emissions into the atmosphere.

Carbon awareness [08:05]

Sara Bergman: So, carbon awareness I think is the third thing we mentioned that we should maybe dive into. But it sounds so sci-fi. Whenever I mention it to an unsuspecting crowd, I'm like, "Yes, now we're going to go off the deep end". But it really isn't super complicated. So, the thing is energy can be produced in different ways. We all know that. Most countries don't have one source, they have multiple. So, the grid mix varies throughout the day, throughout the year and whatnot, over the course of years also as the grid evolves. And carbon awareness is adapting to this fluxuality. It's about listening to real time. What energy do I have right now? Or listen to forecasts and then plan how you operate or what you serve to customers based on that.

Anne Currie: Yes, it's interesting, almost everybody talks mostly about efficiency, and that's a good place to start. It's usually the easiest place to start. It's not hard for people to just go through, and do fairly manual stuff to do with sorting out provisioning and cut their carbon emissions by 50%. That's really not that difficult to do. Carbon awareness is more difficult. It requires you to design your systems, to architect your system, so you have parts of your system that, particularly CPU-heavy parts of your system, workloads that can be shifted in time that can be delayed to when the sun comes up or when the wind starts blowing again.

So, in many ways that's very hard, but in the long term that is absolutely where all the win is because power that's generated from photovoltaic cells, from wind farms, if you can use it directly, is going to be 10 times cheaper, even than fossil fuels. So the wind, if you can find a way to use it, is you will get electricity that's 10 times cheaper, but it's a longer term planning exercise to work out how you're going to produce systems that can shift work, take advantage of that.

What can engineers do to make software more green? [09:59]

Thomas Betts: So, this is what happens with every time I talk about green software, you go into 17 different aspects that we all need to consider and it kind of becomes overwhelming. And it's easy for someone to say, "Well, it's embedded carbon in the iPhone, and so that's clearly not my problem. I'm just an app developer, and so nothing I do makes a difference", or, "It's up to the data centers because they're the ones that are actually plugged in, and are they running on fossil fuels or solar?" So, as the lowly developer or architect, how can you convince those people, no, what you're doing does make a difference?

Anne Currie: Well, that's good because it really does. AWS, Azure I think use the same terminology. They talk about it as a shared responsibility model. Even in the clouds where they're putting tons of effort into providing services that... I know that you hear pros and cons of the cloud. And a big company is not one thing. There's loads of things going on in their big company, but they do want to produce systems that will in the long run deliver zero carbon power because they want some of that 10X cheaper electricity too, thank you very much. So, they want us to produce systems that will run on that cheap green power, but as developers, you have to use those systems. You have to build your applications to run on those offerings that are effectively green platforms that can provide that.

If you don't, if you run, if you just lift and shift from your data center, from your on-prem data center, for example, into the cloud and you just run on a dedicated server, you really don't get that much benefit. You get some benefits, you don't get that much benefit and the clouds will never be able to be green based on that. In order to be green, you have to start modernizing. You have to start using those services like spot instances, the right kind of instance type in order to get the benefit of the investment that they're making, serverless, that kind of thing. Both sides are going to have to step up, and if either side doesn't, you don't end up with a very good solution.

Sara Bergman: Yes, and I think at the very least, use your consumer power. Do your research before choosing where you host your software. And continue to use your consumer power to apply necessary pressure on the topics you're interested in. That goes for everything, of course. And don't eat the elephant in one bite. Is that the saying?

Anne Currie: Oh yes, don't try and eat the elephant in one bite. Yes, that is the saying.

Sara Bergman: Sorry, the two native English speakers need to correct the Swedish person. I don't even know what the Swedish equivalent would be. Anyway, so don't eat the elephant in one bite. Try to break it down. I think most people who have any piece of software, you know where your inefficiencies are, you know the thing you're doing that's kind of a little bit stupid, but you're doing it anyways because of reasons. So, if you can find, for example, a sustainability argument to motivate doing it, I think you're very, very likely going to be able to find other reason for doing it as well. Maybe this is also cheaper. Maybe this also makes your service more reliable. Maybe it increases performance, lower latency. So, bundle those arguments together. Sadly, most people, if you come to them and say, "Hey, we're going to make this 5% greener", they're like, "Okay, you also have to deliver other value".

Publicly talk about making software more green [13:23]

So, bundle it together with other things. And then what I... Maybe this is a... I don't know if it's a secret tip or not, but I think there's a lot of goodwill to be had around publicly talking about this. Say you did something, you could see that it decreased your emissions and you go and talk about it. It can be a positive story. So, even if you are being carbon efficient, you're delivering the same value for lesser carbon, that value can still be that you can talk about it externally. Say, "This is what we did", and your customers will think, "Hey, what a nice company. I want to buy their stuff because I want to be green too", because consumers want to be green.

Thomas Betts: Yes, a lot of corporate sustainability reports are talking about, "Here's our carbon impact. We're trying to go carbon neutral". And it's all playing with the numbers. There's ways of manipulating it so that you look good in a report, but it is for that public campaign saying, "Hey, this is important to us and we're making strides to reduce our footprint". And it started with, "Okay, we're just going to make sure the lights are turned off in the building". And then it turns out everyone went home for COVID and they just never turned the lights back on in the building, so there, big win. But now it is looking at the, what is it, the second and third order effects. We've now put all of our stuff in the cloud, so we have to understand: what is the carbon impact of our software running the cloud as opposed to the data center where it's a little easier to manage and measure?

Anne Currie: There is one downside of advertising and talking about what you're doing, although I really like it when people do. It's fantastic when they do. If you go into the ESG area, they are very keen on getting really accurate numbers. The trouble is that a lot of the times it's really quite hard to get accurate numbers at the moment. And therefore they kind of go, "Well, if I can't the accurate numbers, I'm not even going to start". But there are significant knock-on benefits to being green even if you don't have the number. There are things you can do that are kind of proxy measures for being green and are worthwhile in and of themselves.

So, I often say, "Well, your hosting bill isn't a perfect proxy metric for carbon emissions, but it's not bad and it's a really good place to start". The very basic things that you start with to clear up your systems, like turning off stuff that you're not using anymore just has low value, or you are over-provisioned, get the right sizing everything, that has an immediate impact on your hosting bill.

And I always think that in terms of green, if it isn't at least a double win, it's probably not green. So, to start with, the double win is you cut your cost. And then as you get a bit more sophisticated, the way that you then cut your carbon again is usually by using more modern resilience techniques like autoscaling. Well, that has a triple win there. And you cut your hosting costs. You cut your carbon emissions, but most importantly you get a more resilient system because autoscaling is a lot more resilient than having a cold or even a hot backup somewhere. So again, you're looking at that double win. And if you don't have the double win, ironically it's probably not green because it won't scale.

Proxy measures for how green you are [16:26]

Thomas Betts: You mentioned there were several different proxies. So, the bill is the one, what else can we look at for some sort of measure to say, "Am I green?" beyond just the bill that I'm getting?

Anne Currie: Well, I do quite like the most obvious proxy other than the bill. The bill is the nice easy one want to start with. The more sophisticated one is performance, because as we said, each CPU cycle costs you time and it costs you money and it costs you carbon emissions. So, basically if you can improve the performance of your system, as Sara said, if you could just reduce those niggles, all those performance bugs that you kind of always meant to fix, but you never really got round to fixing, fix those performance bugs, you go faster and you reduce less carbon into the atmosphere.

Sara Bergman: The reason why that works is because you're then cramming more work into your CPU in a shorter amount of time, meaning you might not need two instances or three instances. You can reduce down. Now, if you're in the cloud, that's great because someone else can use that hardware. If you're on-prem, then you might say, "Oh, but I already have all those machines". However you want to think forward as well, into the future in terms of capacity planning. You may not need to buy additional servers if you're using the ones you have more frugally. So, you might be able to maybe even turn someone off and save them for a bit, so that's why performance is a good metric. Don't just speed things up for the sake of it. You speed things up so that you can reduce your footprint.

Green does not require the cloud [17:59]

Thomas Betts: I like that you brought up the on-prem versus in the cloud because I think there's some mindset that, "Oh, I have to go to the cloud or we can't be green", and you can apply these same techniques in your own data center. It's the same thing. You can run microservices yourself, you can host all those things if you need to on your own hardware. Plenty of companies do. And that's the idea, that I shifted from... You said you don't want to just do the straight lift and shift, that's inefficient for all the reasons, but you also have to start thinking about: how do I design my system so that it can auto-scale up and down even though that's on my hardware, and when it scales down, can something else run in its place, so that machine that's still sitting there running is not completely useless, it's actually producing some value?

Anne Currie: Well, or ideally it gets turned off. The ideal is you just turn the stuff off when you're not using it. That is absolutely the dream. In fact, from what Sara said, obviously we're completely in agreement on this, the way I quite like to say it is start with operational efficiency and use cost as your way of measuring that. If you could just run fewer machines, then it's reflected in your energy bill if you're on-prem or your hosting bill if you are in the cloud because you've right-sized or you've got rid of systems that are not doing anything. And then only after you've done that do you think about performance and effectively code level tuning. Because if you start doing the code level tuning before you've got really good at the operations, then you just end up with a whole load of machines that are only partially utilized. So, you've got to start with ops first. So, cost is your first proxy, performance is only a later proxy.

Sara Bergman: Yes, do it in the right order. And I think also maybe something that, if you're not that into green software maybe, haven't heard about them, the reason why we say, "Turn things off", is because there's something called energy proportionality about servers. And this was, I believe, first introduced in 2007 by two Google engineers who wrote this amazing paper, which I recommend people to read. But basically when you turn a server on, it consumes a baseline of power that's pretty high. In their paper it's around 50%. That was an aggregation over... Yes. Point is, it's pretty high and it's not doing anything.

And then as utilization increases, the curve goes up, but even if you just have an idle machine, you're consuming a big chunk of energy, so you want to be mindful of that and have properly utilized machines or turning them off. And I think their paper originally was to propose we do fully energy proportional hardware so that the curve starts at zero and then increases with utilization. I haven't seen any servers that can do that yet. That will be amazing, so looking forward to it. It's very much a research area still, but we're not there yet. So, idle servers consume lots of energy.

Anne Currie: Again, that's something you can do on-prem, is that you can set yourself a target of saying, "Average across my entire estate, have I got between 50 and 80% CPU utilization?" So, above 80% is problematic because you end up with all kinds of other downsides of having all machines that are a little bit highly utilized, but on average, if you can achieve 50% across your estate, then that's a great target.

Thomas Betts: Yes, I think some people will look at a metric and like, "Oh, my CPU is sitting there at like five or 10%, I'm doing great". And that's a mindset you have to get out of. Oh, if that's the only thing that machine's doing, that's over-provisioned.

Anne Currie: Absolutely, yes.

Thomas Betts: You can get the same performance without running at 50%. You're not introducing latency, you're not introducing any other concerns, it's just more of the smaller size CPU. And like you said, someone else can use that CPU for something else if you're on the cloud.

Anne Currie: Yes, indeed. But on-prem too, it just requires a little bit of thought.

Thomas Betts: Right.

Sara Bergman: Yes, yes, you can definitely build the most sustainable data center ever yourself. There is no secret to the cloud. It takes a lot of engineering power.

Multi-tenancy is the efficiency secret sauce in the cloud [21:55]

Anne Currie: Well, there is one magic secret to the cloud, which you can do on-prem, but not very many businesses have the range of workloads to achieve it, which is multi-tenancy. So, the secret source of the cloud is that they've got such a mixture of tenants, and they all have different demand profiles, and they're very good at making sure that you're sharing a machine with people who have different demand profiles. So, maybe it's the other side of the world, so they're busy during the day and then you've got a different time of day. So, basically they're saying, "Well, how do we align these demand profiles so that we never have a quiet machine and we never have an overloaded machine?" So, some companies can do that.

The most famous is probably Google. They're one of the reasons why they're very ahead on all of this stuff and a lot of the interesting thinking in this area came from Google was because from the get-go, from a very early stage, they were effectively their own multi-tenant. And they did quite a lot of work to become even more their own multi-tenant. And the classic is YouTube video. When they bought YouTube, that suddenly made them an excellent multi-tenant because YouTube has a very, very CPU-intensive workload associated with it, which is video transcoding and encoding. And they were always very careful. So, right from the start, there's no SLA on that. They'll say, "Do you know, could be done five minutes, could be done in five hours, could be done tomorrow. Just we'll let you know when it's done".

So, that gives them something they can move around in time to make sure they get really high utilization on their machines. So, excellent example of finding something that effectively could be used to make themselves their own multi-tenant. So, one thing that any enterprise can do is if you can find that CPU-intensive task that you can... If you're in the cloud, stick it in a spot instance. If you're on-prem, you're going to have to orchestrate that yourself in some way. Kubernetes does have a spot instance tool associated with it, so you can do it on-prem. But yes, the secret sauce of the cloud is multi-tenancy. It's hard to manage otherwise.

Sara Bergman: Also Google has been doing... Their YouTube processing, the media processing have been carbon aware since 2021, I believe, which is another fun fact about them.

Shifting in time is better than shifting in space [24:12]

Thomas Betts: But that's the thing, they have the incentive because they are at such a scale, yes, there's the carbon benefit, there's also the cost benefit for them. Because I'm not buying the GCP instance. Google is paying for that. Even though it's one division of Google is paying another division of Google, like, "Please host this software for me", there's still a lot of costs. And so those big things that add up to multi-comma numbers, we can do this and we can get cheaper energy, like you said, if we can run this on solar somewhere else later, then let's just do that. It also gives you the ability, I guess, to follow the sun.

We talk about that for software support, that we have people all around the globe so that we can support our users, but when you say, "I want to move this software", it's not I'm always going to move it to Sweden or Norway or somewhere, I'm going to move it to wherever it might make sense right now, so I don't have to necessarily wait 18 hours. I could just pick a different place potentially?

Anne Currie: You can do, but I have to say, we are more keen on a shift in time than a shift in space. Well, it depends. If it's something with a low amount of data associated with it, then shift it in place. There's no problem. You're not moving a great deal of data. But if you are moving a great deal of data, you're often better off coming up with some cunning wheeze which will enable you to just do the work, either beforehand... Pre-caching is a big thing. You do things in advance, like a CDN does a whole lot of work in advance, or do it later. But yes, that just involves architects coming up with some clever plans for how they can do things early or late.

Sara Bergman: Because we do worry about network costs, like we're spending carbon in the networks because, spoiler alert, networks consume a lot of energy. They have a lot of equipment that eats a lot of electricity. So, sending data on the internet for long distances, if it's a lot of data, we're spending carbon. So, then we're worried that that is actually counter-weighting to the benefit you had of moving it to a greener green time zone. Because of that, again, you can't necessarily easily see where your network is consuming electricity. That's just harder the way the internet works. Also, there are, of course, a lot of, especially in Europe I want to say, legal rules around where you can move data, and you have to be mindful of those things as well.

Various viewpoints and roles for green software [26:29]

Thomas Betts: Well, so you've brought up a couple of different things, the two of you in the last minute. So, Sara was talking about networks. Anne said, "Architects have to come up with these clever solutions". So, the InfoQ audience is engineers, architects, DevOps, SREs. We have all these different personas. And so think about those different people and the different viewpoints, how would a software engineer think about changing their job to be more green versus an architect versus say a DevOps engineer or a platform engineer that's responsible for deploying all this stuff and setting things up?

Anne Currie: I would say that you start with the platform. So, the platform engineers talk to the software engineers talk to the architects, and come up with a platform that's going to work well for what they do. And it has to be a platform that in the long run the platform creators, the people who support that platform, are committed to it being a platform for the future, platform that will be able to run on top of renewable power. So, just for example, Kubernetes are working on all of this, but the clouds... There are some things that the clouds do that are the green platforms, and they talk about as green platforms, and some things that they kind of are clearly not and therefore they don't really mention green associated with them.

So, this is again where Sara was saying you have to use your consumer power. You have to ask, you have to say, "Is that a green platform? Is that a platform that's just going to be able to carry me all the way through to 24/7 carbon-free electricity in 2030 or 2035 or is it not? Is it going to be a dead end for me when I'm going to have to re-platform at some later point?" So, the first thing is make sure you choose the right platform. And then after that, and this is where the techies come in, where the architects come in, it's using that platform as it was intended to be used. So, using that platform really well, which means reading all the docs, learning how to do it, and grasping that platform. Well for a platform engineer now, you need to step back and say, "Is this a green platform?" And if it's not, what's my plan for moving to one?

Well-architected frameworks from cloud providers [28:47]

Sara Bergman: And one place to start could be all three major cloud providers have their own well-architected frameworks and they all have a sustainability section within that, so that can be a good place to get going. I think all three of them could be a bit more comprehensive, but I think they're a very good start. So, no matter who you use, that's a good starting point.

Anne Currie: And it is well worth saying that have a look at the well-architected framework sustainability section for all of them, and that will give you information. You can ask your account manager, but quite often they'll tell you stuff that's not so useful because they don't always know.

A lot of them have a sustainability architectural expert and you can ask to speak to them, and they will know what the green platforms are. But if you just say, "Is this a green platform?" quite often they will say, "Oh, this is already a green platform because we offset everything". So, this is a big thing at the moment. A lot of them are saying, "Oh, well we offset everything, so we'll pay somebody else to..". But that is not enough. Carbon neutral is not carbon zero. It's not getting us there. It's the goal of 10 years ago. And all too often, when you ask a hyperscaler these days, "Is it a green platform?" they'll say, "Yes, because we offset everything", and that is not sufficient.

Thomas Betts: Yes. I still hear companies talking about, "We're going carbon neutral", or, "We made it to carbon neutral", and it's like, "Okay, and next". So, the goal after that is carbon zero, and that's for the data centers, that's for software, that's for hopefully every company eventually. It might not be tomorrow, but it's a goal. You can have these long-term goals.

Anne Currie: Yes, indeed. Carbon neutral, if you're not already there, you are quite behind the times, but it's the first step.

Sustainable AI and LLMs [30:29]

Thomas Betts: Let's go to something that's not carbon neutral: machine learning, AI, LLMs. They get a lot of press of power consumption, data center consumption, CPU. It's like the new Bitcoin mining, "I'm going to go and train an LLM". Some of these numbers are hard to come by. I don't know if you guys have looked into how much it is. And there's two aspects. There's the training of the LLMs and the AI models, and then there's hosting them, which can be less, but if they get used inappropriate, like any software they can also have significant consumption sides to that. So, where are we at with that? What does it look like? Do you have a sense of the impact? And then what do we do about it?

Anne Currie: So, I can talk to where we are and where I think we're likely to be. Sara is the expert in techniques to reduce the carbon associated with creating models or running inference. But from my perspective, yes, there is a great deal of power being used by LLMs at the moment. Do I think that's a problem? Not actually. I'm going to be controversial, and say no, not really because it's very much at the beginning. And it feels to me like it's a gold rush, and all hardware is being used like crazy and nobody's waiting for the sun to shine, Everybody's running everything all the time, that kind of stuff. But fundamentally AI, both training and inference, has the potential to be something that could be shifted to when and where the sun is shining or the wind is blowing. There's loads of potential asynchronicity about those loads.

They're very CPU-intensive, and right now they tend to be urgent, but that is because we're really at this stage terrible at AI. We don't know how to do it. We don't know how to operate it. Inference, for example, is often described as something that has to run instantly, that maybe the training you could do in advance, but inference is instant. But we've got tons of experience of things that need to be done instantly that are not done instantly on the internet.

For example, I mentioned CDNs earlier, content delivery networks. When you want to watch Game of Thrones, it's bit of an old school reference now, but in the olden days when you want to watch Game of Thrones, you say, "I want to watch Game of Thrones now, now. It has to be delivered to me". And back in the very old days, we would've said, "Oh, no, it has to be delivered from the US to the UK now instantly. That's going to be impossible. Oh my goodness me, it's going to overload the internet and everything's going to collapse".

But we learned that that wasn't the way we needed to do things. What we would do is we'd say, "Well, everybody wants to watch a Game of Thrones", so we move it to the UK overnight and we sit it on a CD not very far away from where you live. And it seems like getting it from the US, but you're actually getting it from 100 yards away and it's very quick, and it's kind of a magic trick. You do things in advance. It's a form of pre-caching. Because humans are not that different. They want to watch the same shows, and they want to ask the same questions of AI as well, so there's tons of opportunity for us to get good at caching on inference, I think. And I think that's where we'll go.

But yes, so at the moment it's horrendous, but I don't think it's as bad as Bitcoin. Well, it's similar to Bitcoin at the moment in many ways, but it's not innately as bad as Bitcoin. Bitcoin is purely about using power. And this is actually about achieving a result. And if you can achieve that result using less power, we will. Sara, this is actually your area rather than mine.

Sara Bergman: Yes, we seem to be talking about this a lot lately. I guess everyone in our industry is talking a lot about it lately. I think one of the good things is when I started my journey into how do we build greener software, a lot of the research that was out there was actually AI-related. And specifically on the training side, they're very smart people who've been thinking about this for a long time, which is good. And I think especially on the training, because if you go a few years back, that was maybe the bigger source of emission or at least it was a bit easier to do research on perhaps, so there is a bias there. So, there are tons of things we can do. We can time shift obviously. There are a bunch of methods for making the model smaller. There are tons of research paper that describes techniques on how you can achieve that.

You can also think about on the inference side how you deploy it. If you you think federated learning, are you utilizing your edge networks with moving data and the models closer to your users? And all these things that we had talked about before, like how do you do the operational efficiency for AI workloads, is not super foreign to... You use the same tools, maybe screw them in slightly different ways, but it's very similar. So, we're in good hands there. I think we will learn over time to apply these to the workloads, because, and this is something Anne and I have talked about before, we need to make it green. There isn't an option where we say, "Use AI or be green", because where we are at this point in time, that's not a fair choice. We need to make AI green. That's the thing. And we will definitely, as an industry, get there, I believe.

Anne Currie: Yes, I agree. It's amazing how often we run across people going, "Oh, well, yes, the only green AI is no AI. You turn the AI off". Well, there's only one thing we can be really, really certain of in the tech industry, which is that AI is coming and the energy transition is coming. Both of those things need to be done at once. We cannot pick and choose there.

Sara Bergman: Yes. And I think also what's interesting, because now we have said AI a lot, but I think what we all have meant is generative AI and LLMs. And it's really only one branch of AI. I think we're going to see more approach, and that they will maybe have completely different characteristics that will... And I'm curious to see how that goes. But I think specifically with large language models, we're seeing the rise of small language models, and they're often outperform... So, a specialized small language model often outperforms a more general large language model on specific tasks they're trained for, which is obvious when you think about it. And so I think we're also going to see more of that. Then they also have the benefit they can be closer to you, maybe even on your device because they're small. It's right there in the name.

Thomas Betts: Yes. One of the techniques that is often used for getting the large language model to be better is to throw a larger prompt at it. And it turns out if you have a small language model that's basically trained on what you're prompting with every time, the analogy I liked was you can send someone to med school or whatever and they've spent decades going to school, or somebody wants to be a CPA and be an accountant, they only need to go to a two-year program and they learn how to be an accountant. I need the accounting LLM for my accounting software. I don't need to ask it all about Taylor Swift. If it knows about Taylor Swift, it's not actually a good language model for me to have in my software, and now it's this larger thing that I'm not fully utilizing, just like the larger server that I'm not fully utilizing.

So, I like the idea of get something smaller, and you're going to get better benefits of it. So, it kind of plays into your... There's these co-benefits. So, smaller, faster, AI is greener AI, is greener software.

Thomas Betts: So, I have to call out, there was a talk at QCon San Francisco just last month about GitHub Copilot, and it talked about those same ideas, that they were... It was specifically talking about how to make the requests very quick because they needed to act like this is software running on your machine, in your IDE. And to make that happen, it has to be making local network calls.

So, they have it calling the local Azure instance that has the local AI model or LLM model, LLM, because they can't afford to go across the pond to look it up because it would just take too long and then the software wouldn't work. So, all those things are being discovered as we're finding these large use cases for things like GitHub Copilot.

The Green Software Maturity Matrix [38:28]

Thomas Betts: I do want to give you a chance to talk about the Green Software Maturity Matrix. I mentioned a little bit in your bio, Anne, and so tell us, what is that?

Anne Currie: Well, actually that harks back to something we talked about earlier today in the podcast, that it's very, very complicated. This is something that Sarah and Sara and I really hit writing the book. And we knew from going out and talking at conferences and things about this stuff, there's lots of different things that you can do to be green, and there's lots of different ways you can approach it. And there are some ways to approach it that are just vastly more successful than others. And we spent quite a lot of time thinking in the book about how we could communicate the process that you should use. So, don't try and leap to the end. Don't try and be Google in one leap because you'll fail and then it won't be green. It might be... If you set your goals too high, your bar too high, you'll fail to achieve it, and then you'll go, "Well, it's impossible to be green".

And that isn't the case. You just needed to do it in a more regulated way. So, we put a... A maturity matrix is a project... It's quite an old fashioned project management techniques that basically says, "Well, what does good look like?" But also more importantly it says, "But you're not going to get there in one go. You actually do need to get there in..". A maturity matrix rather arbitrarily chooses five steps to get there. And if you do it through those five steps, you will almost certainly get there. If you don't do it through those five steps, if you try and skip a step, then you will fail miserably.

So, the maturity matrix was basically step one is just want to do it at all. Step two is basic operational efficiency, so turning off things that are not in use, right-sizing. Step three is high-end operational efficiency. This is like modern operational techniques, so autoscaling, using the right services properly. And only at four and five of the matrix do you start doing things like rewriting things in Rust. And ideally most enterprises would never have to achieve four or five because they will adopt a platform at level three that will do four and five for them. So, that's kind of like the idea. It should be, if you follow it, a very successful way to get modern systems that achieve 24/7 carbon free electricity or can run on 24/7 carbon free electricity by stopping you from trying too hard.

Sara Bergman: And it also, I think, nicely separates the vast area of sustainability into swim lanes. So, depending on your role, you can start with the swim lane that feels most natural to you. If you're a product manager, you start in the product. You don't have to start in one of the other ones. And you sort of go from there. And I think that's also a good mental model for people because sometimes when something is new, it can be a bit overwhelming. And spreading it out, not just as five layers, but also nine different categories, really shows that, "Okay, you start with one thing. Just do this cell and then you can sort of expand from there. Just pick any cell in the first level and just start there, and sort of take it step by step".

I always these days start my conference talks with that slide because I think it's a good way to set the expectation, like, "This area is big. Today we're going to focus on this because I can't reasonably talk about everything about sustainability in IT in one hour or how long we have. So, we're going to focus on this. Just know there is more stuff". It also helps prevent the question, "What if I just rewrite everything in Rust?" like Anne said. Because somehow we always get asked that. Somehow I can never escape that question.

Anne Currie: Everybody wants to rewrite their systems in Rust or C. Why? Why?

Sara Bergman: The fan base is massive. Kudos to the Rust folks because you have some hardcore fans out there.

The Building Green Software book club [42:30]

Thomas Betts: We just had a Rust track at QCon, so yes, it's popular. So, this has been a great conversation. I think we're running a little long. I want to give you guys a minute to give a little plug for the Building Green Software Book Club. I attended the first meeting last month, I think it was. What is the book club and how can people find out more about it?

Sara Bergman: So, we're aiming to do once a month, one chapter of the book. We have done one, so so far we're on track. I think there will be maybe a bit of a break now over the holidays, but we'll come back on track. You can find on our LinkedIn pages, we have a link out. You can sign up. It's on Zoom. It's very casual. We chat. You can ask us questions. As you might have noticed in this podcast, we're happy to talk about stuff. So, even if there are no questions, we'll talk anyway. People enjoyed it last time. I enjoyed it. It was very cozy. It was very nice to see people face-to-face virtually. Yes.

Thomas Betts: Well, I'll be sure to add links to the book, to the Maturity Matrix, to the book club in the show notes. Anne and Sara, thanks again for joining me today.

Anne Currie: Thank you again for having us. It was lovely.

Sara Bergman: It was really awesome. Thank you for having us.

Thomas Betts: And listeners, we hope you'll join us again soon for another episode of The InfoQ Podcast.

Mentioned:

About the Authors

More about our podcasts

You can keep up-to-date with the podcasts via our RSS Feed, and they are available via SoundCloud, Apple Podcasts, Spotify, Overcast and YouTube. From this page you also have access to our recorded show notes. They all have clickable links that will take you directly to that part of the audio.

Previous podcasts

Rate this Article

Adoption
Style

BT