37 Star 403 Fork 75

GVPrancher/rancher

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
deployer.go 6.73 KB
一键复制 编辑 原始数据 按行查看 历史
zionwu 提交于 2018-04-24 20:08 . Move alert message to template
package deploy
import (
"github.com/pkg/errors"
"github.com/rancher/norman/controller"
"github.com/rancher/rancher/pkg/controllers/user/alert/manager"
"github.com/rancher/rancher/pkg/image"
"github.com/rancher/types/apis/apps/v1beta2"
"github.com/rancher/types/apis/core/v1"
"github.com/rancher/types/apis/management.cattle.io/v3"
"github.com/rancher/types/config"
"gopkg.in/yaml.v2"
appsv1beta2 "k8s.io/api/apps/v1beta2"
corev1 "k8s.io/api/core/v1"
apierrors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
)
func NewDeployer(cluster *config.UserContext, manager *manager.Manager) *Deployer {
return &Deployer{
nsClient: cluster.Core.Namespaces(""),
appsClient: cluster.Apps.Deployments(""),
secretClient: cluster.Core.Secrets(""),
svcClient: cluster.Core.Services(""),
clusterAlertLister: cluster.Management.Management.ClusterAlerts(cluster.ClusterName).Controller().Lister(),
projectAlertLister: cluster.Management.Management.ProjectAlerts("").Controller().Lister(),
notifierLister: cluster.Management.Management.Notifiers(cluster.ClusterName).Controller().Lister(),
alertManager: manager,
clusterName: cluster.ClusterName,
}
}
type Deployer struct {
nsClient v1.NamespaceInterface
appsClient v1beta2.DeploymentInterface
secretClient v1.SecretInterface
svcClient v1.ServiceInterface
projectAlertLister v3.ProjectAlertLister
clusterAlertLister v3.ClusterAlertLister
notifierLister v3.NotifierLister
alertManager *manager.Manager
clusterName string
}
func (d *Deployer) ProjectSync(key string, alert *v3.ProjectAlert) error {
return d.sync()
}
func (d *Deployer) ClusterSync(key string, alert *v3.ClusterAlert) error {
return d.sync()
}
//deploy or clean up resources(alertmanager deployment, service, namespace) required by alerting.
func (d *Deployer) sync() error {
needDeploy, err := d.needDeploy()
if err != nil {
return errors.Wrapf(err, "Check alertmanager deployment")
}
if needDeploy {
return d.deploy()
}
return d.cleanup()
}
//only deploy the alertmanager when notifier is configured and alert is using it.
func (d *Deployer) needDeploy() (bool, error) {
notifiers, err := d.notifierLister.List("", labels.NewSelector())
if err != nil {
return false, err
}
if len(notifiers) == 0 {
return false, err
}
clusterAlerts, err := d.clusterAlertLister.List("", labels.NewSelector())
if err != nil {
return false, err
}
for _, alert := range clusterAlerts {
if len(alert.Spec.Recipients) > 0 {
return true, nil
}
}
projectAlerts, err := d.projectAlertLister.List("", labels.NewSelector())
if err != nil {
return false, nil
}
for _, alert := range projectAlerts {
if controller.ObjectInCluster(d.clusterName, alert) {
if len(alert.Spec.Recipients) > 0 {
return true, nil
}
}
}
return false, nil
}
func (d *Deployer) cleanup() error {
err := d.nsClient.Delete("cattle-alerting", &metav1.DeleteOptions{})
if err != nil && !apierrors.IsNotFound(err) {
return err
}
d.alertManager.IsDeploy = false
return nil
}
func (d *Deployer) deploy() error {
//TODO: cleanup resources while there is not any alert configured
ns := &corev1.Namespace{
ObjectMeta: metav1.ObjectMeta{
Name: "cattle-alerting",
},
}
if _, err := d.nsClient.Create(ns); err != nil && !apierrors.IsAlreadyExists(err) {
return errors.Wrapf(err, "Creating ns")
}
secret := d.getSecret()
if _, err := d.secretClient.Create(secret); err != nil && !apierrors.IsAlreadyExists(err) {
return errors.Wrapf(err, "Creating secret")
}
deployment := getDeployment()
if _, err := d.appsClient.Create(deployment); err != nil && !apierrors.IsAlreadyExists(err) {
return errors.Wrapf(err, "Creating deployment")
}
service := getService()
if _, err := d.svcClient.Create(service); err != nil && !apierrors.IsAlreadyExists(err) {
return errors.Wrapf(err, "Creating service")
}
d.alertManager.IsDeploy = true
return nil
}
func (d *Deployer) getSecret() *corev1.Secret {
cfg := d.alertManager.GetDefaultConfig()
data, err := yaml.Marshal(cfg)
if err != nil {
return nil
}
return &corev1.Secret{
ObjectMeta: metav1.ObjectMeta{
Namespace: "cattle-alerting",
Name: "alertmanager",
},
Data: map[string][]byte{
"config.yml": data,
"notification.tmpl": []byte(NotificationTmpl),
},
}
}
func getService() *corev1.Service {
return &corev1.Service{
ObjectMeta: metav1.ObjectMeta{
Namespace: "cattle-alerting",
Name: "alertmanager-svc",
},
Spec: corev1.ServiceSpec{
Selector: map[string]string{
"app": "alertmanager",
},
Ports: []corev1.ServicePort{
{
Name: "alertmanager",
Port: 9093,
},
},
},
}
}
func getDeployment() *appsv1beta2.Deployment {
replicas := int32(1)
return &appsv1beta2.Deployment{
ObjectMeta: metav1.ObjectMeta{
Namespace: "cattle-alerting",
Name: "alertmanager",
},
Spec: appsv1beta2.DeploymentSpec{
Replicas: &replicas,
Selector: &metav1.LabelSelector{
MatchLabels: map[string]string{"app": "alertmanager"},
},
Template: corev1.PodTemplateSpec{
ObjectMeta: metav1.ObjectMeta{
Labels: map[string]string{"app": "alertmanager"},
Name: "alertmanager",
},
Spec: corev1.PodSpec{
Containers: []corev1.Container{
{
Name: "alertmanager",
Image: image.Resolve(v3.ToolsSystemImages.AlertSystemImages.AlertManager),
Args: []string{"-config.file=/etc/alertmanager/config.yml", "-storage.path=/alertmanager"},
Ports: []corev1.ContainerPort{
{
Name: "alertmanager",
ContainerPort: 9093,
},
},
VolumeMounts: []corev1.VolumeMount{
{
Name: "alertmanager",
MountPath: "/alertmanager",
},
{
Name: "config-volume",
MountPath: "/etc/alertmanager",
},
},
},
{
Name: "alertmanager-helper",
Image: image.Resolve(v3.ToolsSystemImages.AlertSystemImages.AlertManagerHelper),
Command: []string{"alertmanager-helper"},
Args: []string{"--watched-file-list", "/etc/alertmanager"},
VolumeMounts: []corev1.VolumeMount{
{
Name: "config-volume",
MountPath: "/etc/alertmanager",
},
},
},
},
Volumes: []corev1.Volume{
{
Name: "alertmanager",
VolumeSource: corev1.VolumeSource{
EmptyDir: &corev1.EmptyDirVolumeSource{},
},
},
{
Name: "config-volume",
VolumeSource: corev1.VolumeSource{
Secret: &corev1.SecretVolumeSource{
SecretName: "alertmanager",
},
},
},
},
},
},
},
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/rancher/rancher.git
git@gitee.com:rancher/rancher.git
rancher
rancher
rancher
v2.0.8

搜索帮助