stackube/cmd/stackube-controller/stackube-controller.go
Pengfei Ni c847f5e5a5 Add service controller
- Add a service controller in stackube and create lbaas v2 pools for new services,
also add members for endpoints.
- Fix getting network for system namespaces.

Change-Id: I7942a2d26dd33b4ceb75ec51c03933205a60aea7
Implements: blueprint service-loadbalancer
Signed-off-by: Pengfei Ni <feiskyer@gmail.com>
2017-07-26 20:54:24 +08:00

131 lines
3.8 KiB
Go

package main
import (
"context"
"fmt"
"os"
"os/signal"
"syscall"
"git.openstack.org/openstack/stackube/pkg/auth-controller/rbacmanager"
"git.openstack.org/openstack/stackube/pkg/auth-controller/tenant"
"git.openstack.org/openstack/stackube/pkg/network-controller"
"git.openstack.org/openstack/stackube/pkg/openstack"
"git.openstack.org/openstack/stackube/pkg/service-controller"
"git.openstack.org/openstack/stackube/pkg/util"
extclientset "k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset"
"k8s.io/client-go/kubernetes"
"github.com/golang/glog"
"github.com/spf13/pflag"
"golang.org/x/sync/errgroup"
)
var (
kubeconfig = pflag.String("kubeconfig", "/etc/kubernetes/admin.conf",
"path to kubernetes admin config file")
cloudconfig = pflag.String("cloudconfig", "/etc/stackube.conf",
"path to stackube config file")
userCIDR = pflag.String("user-cidr", "10.244.0.0/16", "user Pod network CIDR")
userGateway = pflag.String("user-gateway", "10.244.0.1", "user Pod network gateway")
)
func startControllers(kubeClient *kubernetes.Clientset,
osClient *openstack.Client, kubeExtClient *extclientset.Clientset) error {
// Creates a new Tenant controller
tenantController, err := tenant.NewTenantController(kubeClient, osClient, kubeExtClient)
if err != nil {
return err
}
// Creates a new Network controller
networkController, err := network.NewNetworkController(osClient, kubeExtClient)
if err != nil {
return err
}
// Creates a new RBAC controller
rbacController, err := rbacmanager.NewRBACController(kubeClient, osClient.CRDClient, *userCIDR, *userGateway)
if err != nil {
return err
}
// Creates a new service controller
serviceController, err := service.NewServiceController(kubeClient, osClient)
if err != nil {
return err
}
ctx, cancel := context.WithCancel(context.Background())
wg, ctx := errgroup.WithContext(ctx)
// start auth controllers in stackube
wg.Go(func() error { return tenantController.Run(ctx.Done()) })
wg.Go(func() error { return rbacController.Run(ctx.Done()) })
// start network controller
wg.Go(func() error { return networkController.Run(ctx.Done()) })
// start service controller
wg.Go(func() error { return serviceController.Run(ctx.Done()) })
term := make(chan os.Signal)
signal.Notify(term, os.Interrupt, syscall.SIGTERM)
select {
case <-term:
glog.V(4).Info("Received SIGTERM, exiting gracefully...")
case <-ctx.Done():
}
cancel()
if err := wg.Wait(); err != nil {
glog.Errorf("Unhandled error received: %v", err)
return err
}
return nil
}
func initClients() (*kubernetes.Clientset, *openstack.Client, *extclientset.Clientset, error) {
// Create kubernetes client config. Use kubeconfig if given, otherwise assume in-cluster.
config, err := util.NewClusterConfig(*kubeconfig)
if err != nil {
return nil, nil, nil, fmt.Errorf("failed to build kubeconfig: %v", err)
}
kubeClient, err := kubernetes.NewForConfig(config)
if err != nil {
return nil, nil, nil, fmt.Errorf("failed to create kubernetes clientset: %v", err)
}
kubeExtClient, err := extclientset.NewForConfig(config)
if err != nil {
return nil, nil, nil, fmt.Errorf("failed to create kubernetes apiextensions clientset: %v", err)
}
// Create OpenStack client from config file.
osClient, err := openstack.NewClient(*cloudconfig, *kubeconfig)
if err != nil {
return nil, nil, nil, fmt.Errorf("could't initialize openstack client: %v", err)
}
return kubeClient, osClient, kubeExtClient, nil
}
func main() {
util.InitFlags()
util.InitLogs()
defer util.FlushLogs()
// Initilize kubernetes and openstack clients.
kubeClient, osClient, kubeExtClient, err := initClients()
if err != nil {
glog.Fatal(err)
}
// Start stackube controllers.
if err := startControllers(kubeClient, osClient, kubeExtClient); err != nil {
glog.Fatal(err)
}
}