From Fedora Project Wiki

No edit summary
(update wip from etherpad)
Line 2: Line 2:


'''Working on this now at''' http://cloudpad-samkottler.rhcloud.com/p/CloudChanges
'''Working on this now at''' http://cloudpad-samkottler.rhcloud.com/p/CloudChanges
----
== Brainstorming ==
Remove this section as ideas are put into a more structured form (or discarded).
* Retire appliance-creator
** Anaconda-based installs are the way forward
*** Needs new ImageFactory release
*** Patch Koji for ImageFactory support
*** Then, needs new Koji release
*** Then, push new Koji release to Fedora production
* Extend AutoQA to allow for automated testing of cloud images (if not already possible)
* Automate rel-eng
** produce scratch builds on change (note: we already have nightly images of rawhide and branched compose for months)
** upload final release and re-release images to ec2 and ftp
* Updated Web Site for Obtaining Cloud Images
** Easier access to provided images for various use cases
** Provide build toolchain
** encourage community to use toolchain to build new products
** Allow folks to share and review the work done by their peers
* Implement new procedures for (a)periodical re-releases
* Ensure usability of software stacks for cloud usage
** Always have several different versions (major or minor releases, i.e. non-bugfix releases) ready for installation
** Make sure older versions are supported and available as long as possible, particularly with new Fedora releases
*** i.e. apps running on F21 cloud images should still be able to run on F22 cloud images (and F23? How long should they work?)
* More modularly-packaged kernel (modules that are not necessary in virtualized environments need become optionally installable)
* More modularly-packaged (or written?) SELinux policies
* Make it possible to install without l10n/i18n support (no extra languages, etc.) but keep the possibility to install them
* Make it possible to install packages without documentation (to save space) but keep the possibility to install them
== Suggested Structure ==
== Suggested Structure ==
Basically, each of these are going to become a Change using the Fedora Features process ([[Changes/Policy]]). So, each should be a very lightweight version of [[Changes/EmptyTemplate]]. We should also rate each one for importance (overall/strategically) and urgency (things that need to get done *now*, things that need to land in f21, things that can land after) + a rationale for the urgency (blocks something, competitive need, etc).
Basically, each of these are going to become a Change using the Fedora Features process ([[Changes/Policy]]). So, each should be a very lightweight version of [[Changes/EmptyTemplate]]. We should also rate each one for importance (overall/strategically) and urgency (things that need to get done *now*, things that need to land in f21, things that can land after) + a rationale for the urgency (blocks something, competitive need, etc).
So, I'm envisioning a list here which looks like this:
So, I'm envisioning a list here which looks like this:
----
----
=== Change: ''Change Name'' ===
=== Change: ''Change Name'' ===
'''Summary:''' Elevator pitch for the change.
'''Summary:''' Elevator pitch for the change.
'''Importance:''' [ vital | moderate | nice-to-have ]
'''Importance:''' [ vital | moderate | nice-to-have ]
'''Timeframe:''' [ now | F21 alpha | F21 beta | F21 release | F22 | F23+ ] / reason (e.g. "blocks ability to produce images" )
'''Timeframe:''' [ now | F21 alpha | F21 beta | F21 release | F22 | F23+ ] / reason (e.g. "blocks ability to produce images" )
'''Scope:''' [ self-contained | complex system-wide ]
'''Scope:''' [ self-contained | complex system-wide ]
''link to change proposal page (can be not actually filled out yet)''
''link to change proposal page (can be not actually filled out yet)''
----
----
Additionally, we are going to have '''dependencies''' on changes that are largely in other Fedora groups. These aren't really ''our'' changes, so we shouldn't be submitting them, but we should also list them. The enhanced automatic QA features of taskotron would be an example. Web design and marketing are others. So, something like:
Additionally, we are going to have '''dependencies''' on changes that are largely in other Fedora groups. These aren't really ''our'' changes, so we shouldn't be submitting them, but we should also list them. The enhanced automatic QA features of taskotron would be an example. Web design and marketing are others. So, something like:
----
----
=== External Need: ''Dependency Name'' ===
=== External Need: ''Dependency Name'' ===
'''Summary:''' Elevator pitch for the change.
'''Summary:''' Elevator pitch for the change.
'''Importance:''' [ vital | moderate | nice-to-have ]
'''Importance:''' [ vital | moderate | nice-to-have ]
'''Timeframe:''' [ now | F21 alpha | F21 beta | F21 release | F22 | F23+ ] / reason (e.g. "blocks ability to produce images" )
'''Timeframe:''' [ now | F21 alpha | F21 beta | F21 release | F22 | F23+ ] / reason (e.g. "blocks ability to produce images" )
'''Fedora Sub-Project/SIG:''' [ QA | Websites | etc ]
'''Fedora Sub-Project/SIG:''' [ QA | Websites | etc ]
'''Cloud SIG owner:''' (We can't just demand things, obviously. Who from our group is going to interface and possibly contribute?)
'''Cloud SIG owner:''' (We can't just demand things, obviously. Who from our group is going to interface and possibly contribute?)
''link to relevant whatever''
''link to relevant whatever''
----
----
REAL STUFF STARTS BELOW HERE
== The List ==
----
=== Change: Move to ImageFactory For image Creation ===
'''Summary:''' Create images using Anaconda in Koji rather than obsolete, unmaintained appliance-creator. Allows fedmsg integration for upload service, and also could produce official Docker images.
'''Importance:''' vital (basic image creation is nice-to-have, fedmsg integration is important to automation, and producing Docker images is strategically vital)
'''Timeframe:''' at least a month lead time before F21 alpha / If we are going to release images made this way, we need them made that way for early testing, and there will be some porting work to the kickstart
'''Scope:''' self-contained (work with Rel Eng)
https://fedoraproject.org/wiki/Changes/ImageFactory_in_Koji
----
=== External Need: Automatic Image Upload ===
'''Summary:'''  Whenever an image is built, it is automatically uploaded to our cloud provider targets (EC2, etc.) and to the fedora ftp site (and possibly mirrors if we can convince mirror admins to drink from that firehose)
'''Importance:'''  vital (current process where rel eng does it by hand will not scale)
'''Timeframe:''' whenever we can get it / this adds value whenever it happens
'''Fedora Sub-Project/SIG:''' Release Engineering, possibly Infrastructure for resources
'''Cloud SIG owner:''' ???????? (note summer intern may help with that, if it is not too late)
(need link to something further -- possibly we file this as a change)
----
=== External Need: Automatic Smoketests on Image Build ===
'''Summary:''' When a new image is built in Koji, automatically boot it and run a basic matrix of tests.
'''Importance:''' moderate (worst case, we can keep doing this by hand)
'''Timeframe:''' F21 alpha / Want to reduce manual test workload
'''Fedora Sub-Project/SIG:''' QA and the Taskotran project
'''Cloud SIG owner:''' ????????
https://fedoraproject.org/wiki/User:Tflink/taskotron_development_plan
----
=== External Need: Scratch Builds on Change ===
'''Summary:''' Whenever the kickstart changes, _or_ an RPM which is on the image hits the tree, a new scratch image is automatically built.
'''Importance:''' nice to have (makes development much easier, and makes it quick to spot and fix problems before they affect anyone)
'''Timeframe:''' whenever we can get it / this adds value whenever it happens
'''Fedora Sub-Project/SIG:''' Release Engineering, possibly Infrastructure for resources
'''Cloud SIG owner:''' ????????
(need link to something further -- possibly we file this as a change)
----
=== External Need: Updated Web Site===
'''Summary:''' Since we are now one of the three top level artifacts Fedora produces, we want to emphasize our unique niche. Updated website with new flashier branding, plus tools for selecting different images for different use cases
'''Importance:''' vital (it's basically part of the whole exercise
'''Timeframe:''' F21 release / arguably, having the web site up _is_ the release. And it'd be nice to have earlier, like at the alpha and beta
'''Fedora Sub-Project/SIG:''' Websites
'''Cloud SIG owner:'''  Joe Brockmeier
https://fedorahosted.org/fedora-websites/ticket/248
----
=== Change: Docker Host Image ===
'''Summary:''' Fedora Cloud agreed to  make a base image plus several tailored to specific purposes. This is one of the tailored ones — Docker host ready to go.
'''Importance:''' moderate (Docker is hot stuff and we need an answer to CoreOS, but if we fail to do it, we are not any worse-off than we are now, and Docker can still be used on the base iamge.)
'''Timeframe:''' F21 alpha / If it's not ready for alpha, we have missed this release
'''Scope:''' self-contained
https://fedoraproject.org/wiki/Changes/Docker_Cloud_Image
----
=== Change: Big Data Image ===
'''Summary:'''  Fedora Cloud agreed to  make a base image plus several tailored to  specific purposes. This is one of the tailored ones, produced in collaboration with the Big Data SIG.
'''Importance:'''  nice to have (if we fail to do it, we are not any worse-off than we are now, and big data tools can still be used on the base iamge.)
'''Timeframe:''' F21 alpha / If it's not ready for alpha, we have missed this release
'''Scope:''' self-contained
https://fedoraproject.org/wiki/Changes/Big_Data_Cloud_Image
----
=== Change: OpenShift Out-of-the-Box Image ===
'''Summary:'''  Fedora Cloud agreed to  make a base image plus several tailored to  specific purposes. This is one of the tailored ones — OpenShift ready to run.
'''Importance:'''  nice to have (if we fail to do it, we are not any worse-off than we are now, and OpenShift can still be installed on the base iamge.)
'''Timeframe:''' F21 alpha / If it's not ready for alpha, we have missed this release
'''Scope:''' self-contained
https://fedoraproject.org/wiki/Changes/Big_Data_Cloud_Image
----
=== Change: Docker Container Image ===
'''Summary:'''  This is Fedora running inside Docker. Currently, there are non-official images in the docker index, but we'd like them to really come out of release engineering.
'''Importance:'''  nice to have (The unofficial image situation is not ideal. Plus, this is an area where we can show leadership.)
'''Timeframe:''' F21 alpha / If it's not ready for alpha, we have missed this release
'''Scope:''' self-contained
https://fedoraproject.org/wiki/Changes/Docker_Container_Image
=== Change: (A)Periodic Updates to the Images ===
'''Summary:''' We want to be able to release updated images not just at release time. Hope for a one-month regular cadence, plus emergency updates if needed.
'''Importance:'''  vital (People don't like to yum update their images, and since we change so much, doing so is a significant launceh delay. let's make it so they don't have to, but still get updates)
'''Timeframe:''' F21 final + 1 month / Obviously better if we get things lined up earlier
'''Scope:''' self-contained
https://fedoraproject.org/wiki/Changes/(A)Periodic_Updates_to_Images
----
=== External Need: ''Batched Updates'' ===
'''Summary:''' We want to produce updated images on a monthly cadence. It would be nice if we could produce those from QA'd bunches of packages.
'''Importance:''' moderate (it will be hard to implement image refresh without this, but we could do it)
'''Timeframe:''' F21 release + 1 month / Obviously better if we get things lined up earlier
'''Fedora Sub-Project/SIG:''' Primarily QA, but Rel Eng and Infrastructure too. This is pretty big.
'''Cloud  SIG owner:''' ???????? (this probably needs someone actively contributing to initial and ongoing work)
http://flock2013.sched.org/event/8c4f702e42814598e0e4e31b188a0ae6
----
=== Change: Install without i10n / l18n support (w/optional install) ===
'''Summary.''' We need to have a cloud image without the overhead/extra space requirements of i10n / l18n support, but want to provide the option to install these packages if needed. In many cases these are not necessary for images running in the cloud.
'''Importance.''' moderate (Should not be overly difficult to implement, but is not a show-stopper if it's not complete by F21.)
'''Timeframe.''' F21 alpha / should be at least mostly implemented by alpha or won't be ready for this release.
'''Scope.''' self-contained
'''Cloud SIG owner.''' mattdm (I already have a conversation open with anaconda and the packaging team)
https://fedoraproject.org/wiki/Changes/Optional_i10n_and_l18n_support_cloud_image
----
=== Change: Install without documentation (w/optional install later) ===
'''Summary.''' In many cases, users will not want documentation on cloud images. We should be able to provide support to create/deliver cloud images without documentation but still have it available for installation if desired.
'''Importance.''' moderate
'''Timeframe.''' F21 alpha / should be at least mostly implemented by alpha or will not be ready for this release.
''' Scope.''' self-contained
'''Cloud SIG owner.''' ???????
https://fedoraproject.org/wiki/Changes/Optional_documentation_cloud_image
----
=== External Need: Software Collections for Cloud Users ===
'''Summary:'''
'''Importance:''' vital (provides a meaningful reason to use Fedora cloud image, and helps insulate against rapid change)
'''Timeframe:''' F21 release / This is a requirement of users in production.
'''Fedora Sub-Project/SIG:''' Environments and Stacks
'''Cloud  SIG owner:''' ????????
''link to relevant whatever''
----
=== Change: Cloud-Friendly Kernel Packaging' ===
'''Summary:''' Modules that are not necessary in virtualized environments become optionally installable
'''Importance:''' nice-to-have
'''Timeframe:''' F21 beta / need widespread testing to make sure nothing really needed is left out
'''Scope:''' self-contained (kernel team with input/feedback from cloud)
https://fedoraproject.org/wiki/Changes/Modular_Kernel_Packaging_for_Cloud
----
=== Change: Modularized SELinux Packaging' ===
'''Summary:''' Monolith SELinux policy has rules for everything that could exist, not just that which is installed. Possible room for reduction here.
'''Importance:''' nice-to-have
'''Timeframe:''' F21 or F22 / This is not low-hanging fruit.
'''Scope:''' self-contained (SELinux)
(No Feature filed at this time -- discuss with SELinux policy maintainers)

Revision as of 17:50, 28 February 2014


Working on this now at http://cloudpad-samkottler.rhcloud.com/p/CloudChanges

Suggested Structure

Basically, each of these are going to become a Change using the Fedora Features process (Changes/Policy). So, each should be a very lightweight version of Changes/EmptyTemplate. We should also rate each one for importance (overall/strategically) and urgency (things that need to get done *now*, things that need to land in f21, things that can land after) + a rationale for the urgency (blocks something, competitive need, etc). So, I'm envisioning a list here which looks like this:


Change: Change Name

Summary: Elevator pitch for the change. Importance: [ vital | moderate | nice-to-have ] Timeframe: [ now | F21 alpha | F21 beta | F21 release | F22 | F23+ ] / reason (e.g. "blocks ability to produce images" ) Scope: [ self-contained | complex system-wide ] link to change proposal page (can be not actually filled out yet)


Additionally, we are going to have dependencies on changes that are largely in other Fedora groups. These aren't really our changes, so we shouldn't be submitting them, but we should also list them. The enhanced automatic QA features of taskotron would be an example. Web design and marketing are others. So, something like:


External Need: Dependency Name

Summary: Elevator pitch for the change. Importance: [ vital | moderate | nice-to-have ] Timeframe: [ now | F21 alpha | F21 beta | F21 release | F22 | F23+ ] / reason (e.g. "blocks ability to produce images" ) Fedora Sub-Project/SIG: [ QA | Websites | etc ] Cloud SIG owner: (We can't just demand things, obviously. Who from our group is going to interface and possibly contribute?) link to relevant whatever


REAL STUFF STARTS BELOW HERE

The List


Change: Move to ImageFactory For image Creation

Summary: Create images using Anaconda in Koji rather than obsolete, unmaintained appliance-creator. Allows fedmsg integration for upload service, and also could produce official Docker images. Importance: vital (basic image creation is nice-to-have, fedmsg integration is important to automation, and producing Docker images is strategically vital) Timeframe: at least a month lead time before F21 alpha / If we are going to release images made this way, we need them made that way for early testing, and there will be some porting work to the kickstart Scope: self-contained (work with Rel Eng) https://fedoraproject.org/wiki/Changes/ImageFactory_in_Koji


External Need: Automatic Image Upload

Summary: Whenever an image is built, it is automatically uploaded to our cloud provider targets (EC2, etc.) and to the fedora ftp site (and possibly mirrors if we can convince mirror admins to drink from that firehose) Importance: vital (current process where rel eng does it by hand will not scale) Timeframe: whenever we can get it / this adds value whenever it happens Fedora Sub-Project/SIG: Release Engineering, possibly Infrastructure for resources Cloud SIG owner: ???????? (note summer intern may help with that, if it is not too late) (need link to something further -- possibly we file this as a change)


External Need: Automatic Smoketests on Image Build

Summary: When a new image is built in Koji, automatically boot it and run a basic matrix of tests. Importance: moderate (worst case, we can keep doing this by hand) Timeframe: F21 alpha / Want to reduce manual test workload Fedora Sub-Project/SIG: QA and the Taskotran project Cloud SIG owner: ???????? https://fedoraproject.org/wiki/User:Tflink/taskotron_development_plan


External Need: Scratch Builds on Change

Summary: Whenever the kickstart changes, _or_ an RPM which is on the image hits the tree, a new scratch image is automatically built. Importance: nice to have (makes development much easier, and makes it quick to spot and fix problems before they affect anyone) Timeframe: whenever we can get it / this adds value whenever it happens Fedora Sub-Project/SIG: Release Engineering, possibly Infrastructure for resources Cloud SIG owner: ???????? (need link to something further -- possibly we file this as a change)


External Need: Updated Web Site

Summary: Since we are now one of the three top level artifacts Fedora produces, we want to emphasize our unique niche. Updated website with new flashier branding, plus tools for selecting different images for different use cases Importance: vital (it's basically part of the whole exercise Timeframe: F21 release / arguably, having the web site up _is_ the release. And it'd be nice to have earlier, like at the alpha and beta Fedora Sub-Project/SIG: Websites Cloud SIG owner: Joe Brockmeier https://fedorahosted.org/fedora-websites/ticket/248


Change: Docker Host Image

Summary: Fedora Cloud agreed to make a base image plus several tailored to specific purposes. This is one of the tailored ones — Docker host ready to go. Importance: moderate (Docker is hot stuff and we need an answer to CoreOS, but if we fail to do it, we are not any worse-off than we are now, and Docker can still be used on the base iamge.) Timeframe: F21 alpha / If it's not ready for alpha, we have missed this release Scope: self-contained https://fedoraproject.org/wiki/Changes/Docker_Cloud_Image


Change: Big Data Image

Summary: Fedora Cloud agreed to make a base image plus several tailored to specific purposes. This is one of the tailored ones, produced in collaboration with the Big Data SIG. Importance: nice to have (if we fail to do it, we are not any worse-off than we are now, and big data tools can still be used on the base iamge.) Timeframe: F21 alpha / If it's not ready for alpha, we have missed this release Scope: self-contained https://fedoraproject.org/wiki/Changes/Big_Data_Cloud_Image


Change: OpenShift Out-of-the-Box Image

Summary: Fedora Cloud agreed to make a base image plus several tailored to specific purposes. This is one of the tailored ones — OpenShift ready to run. Importance: nice to have (if we fail to do it, we are not any worse-off than we are now, and OpenShift can still be installed on the base iamge.) Timeframe: F21 alpha / If it's not ready for alpha, we have missed this release Scope: self-contained https://fedoraproject.org/wiki/Changes/Big_Data_Cloud_Image


Change: Docker Container Image

Summary: This is Fedora running inside Docker. Currently, there are non-official images in the docker index, but we'd like them to really come out of release engineering. Importance: nice to have (The unofficial image situation is not ideal. Plus, this is an area where we can show leadership.) Timeframe: F21 alpha / If it's not ready for alpha, we have missed this release Scope: self-contained https://fedoraproject.org/wiki/Changes/Docker_Container_Image

Change: (A)Periodic Updates to the Images

Summary: We want to be able to release updated images not just at release time. Hope for a one-month regular cadence, plus emergency updates if needed. Importance: vital (People don't like to yum update their images, and since we change so much, doing so is a significant launceh delay. let's make it so they don't have to, but still get updates) Timeframe: F21 final + 1 month / Obviously better if we get things lined up earlier Scope: self-contained https://fedoraproject.org/wiki/Changes/(A)Periodic_Updates_to_Images


External Need: Batched Updates

Summary: We want to produce updated images on a monthly cadence. It would be nice if we could produce those from QA'd bunches of packages. Importance: moderate (it will be hard to implement image refresh without this, but we could do it) Timeframe: F21 release + 1 month / Obviously better if we get things lined up earlier Fedora Sub-Project/SIG: Primarily QA, but Rel Eng and Infrastructure too. This is pretty big. Cloud SIG owner: ???????? (this probably needs someone actively contributing to initial and ongoing work) http://flock2013.sched.org/event/8c4f702e42814598e0e4e31b188a0ae6


Change: Install without i10n / l18n support (w/optional install)

Summary. We need to have a cloud image without the overhead/extra space requirements of i10n / l18n support, but want to provide the option to install these packages if needed. In many cases these are not necessary for images running in the cloud. Importance. moderate (Should not be overly difficult to implement, but is not a show-stopper if it's not complete by F21.) Timeframe. F21 alpha / should be at least mostly implemented by alpha or won't be ready for this release. Scope. self-contained Cloud SIG owner. mattdm (I already have a conversation open with anaconda and the packaging team) https://fedoraproject.org/wiki/Changes/Optional_i10n_and_l18n_support_cloud_image


Change: Install without documentation (w/optional install later)

Summary. In many cases, users will not want documentation on cloud images. We should be able to provide support to create/deliver cloud images without documentation but still have it available for installation if desired. Importance. moderate Timeframe. F21 alpha / should be at least mostly implemented by alpha or will not be ready for this release. Scope. self-contained Cloud SIG owner. ??????? https://fedoraproject.org/wiki/Changes/Optional_documentation_cloud_image


External Need: Software Collections for Cloud Users

Summary: Importance: vital (provides a meaningful reason to use Fedora cloud image, and helps insulate against rapid change) Timeframe: F21 release / This is a requirement of users in production. Fedora Sub-Project/SIG: Environments and Stacks Cloud SIG owner: ???????? link to relevant whatever


Change: Cloud-Friendly Kernel Packaging'

Summary: Modules that are not necessary in virtualized environments become optionally installable Importance: nice-to-have Timeframe: F21 beta / need widespread testing to make sure nothing really needed is left out Scope: self-contained (kernel team with input/feedback from cloud) https://fedoraproject.org/wiki/Changes/Modular_Kernel_Packaging_for_Cloud


Change: Modularized SELinux Packaging'

Summary: Monolith SELinux policy has rules for everything that could exist, not just that which is installed. Possible room for reduction here. Importance: nice-to-have Timeframe: F21 or F22 / This is not low-hanging fruit. Scope: self-contained (SELinux) (No Feature filed at this time -- discuss with SELinux policy maintainers)