14.代理模式--Proxy

原文地址:http://blog.csdn.net/jjunjoe/article/details/6673076

Proxy模式:
Proxy模式为其他对象提供一种代理以控制对这个对象的访问

Proxy一般分为三种:
1. 远程代理,也就是为一个对象在不同的地址空间提供局部代表。这样可以隐藏一个对象存在于不同地址空间的事实。
2. 虚拟代理,是根据需要创建开销很大的对象。通过它来存放实例化需要很长时间的真实对象。比如打开网页时,里面有很多文字和图片,但还是可以很快打开它,先看到的是文字,图片却是一张张下载后才能看到。那些未打开的图片框,就是通过了虚拟代理来替代了真实的图片,此时代理存储了真实图片的路径和尺寸。
3. 安全代理,用来控制真实对象访问时的权限。一般用于对象应该有不同的访问权限的时候。
4. 职能指针,是指当调用真实的对象是,代理处理另外一些事。如计算真实对象的引用次数,这样当该对象没有引用时,可以自动释放它;或当第一次用用一个持久对象时,将它装入内存;或在访问一个实际对象前,检查是否已经锁定它,以确保其他对象不能改变它。

Proxy模式典型的结构图为:
 

其实现代码如下:

//Proxy.h
#ifndef _PROXY_H_
#define _PROXY_H_

class Subject
{
public:
    virtual ~Subject();
    virtual void Request() = 0;
protected:
    Subject();
private:
};

class ConcreteSubject : public Subject
{
public:
    ConcreteSubject();
    ~ConcreteSubject();
    void Request();
protected:
private:
};

class Proxy : public Subject
{
public:
    Proxy();
//     Proxy(Subject* sub);
    ~Proxy();
    void Request();
protected:
private:
    Subject* _sub;
};
#endif //~_PROXY_H_


//Proxy.cpp
#include "Proxy.h"
#include <iostream>
using namespace std;

Subject::Subject()
{
}

Subject::~Subject()
{
}

ConcreteSubject::ConcreteSubject()
{
}

ConcreteSubject::~ConcreteSubject()
{
}

void ConcreteSubject::Request()
{
    cout<<"ConcreteSubject......request...."<<endl;
}

Proxy::Proxy()
{
    _sub = NULL;
}

// Proxy::Proxy(Subject* sub)
// {
//     _sub = sub;
// }

Proxy::~Proxy()
{
    delete _sub;
}

void Proxy::Request()
{
    cout<<"Proxy request...."<<endl;

    // 使用时才初始化
    if ( NULL == _sub )
    {
        _sub = new ConcreteSubject();

    }
    _sub->Request();
}


//main.cpp
#include "Proxy.h"
#include <iostream>
using namespace std;

int main(int argc,char* argv[])
{
//     Subject* sub = new ConcreteSubject();

    Subject* p = new Proxy(/*sub*/);
    p->Request();

    return 0;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,首先你需要确保已经安装了 Docker 和 Docker Compose。 接下来,你可以按照以下步骤来安装 zabbix-proxy5.0.31: 1. 创建一个名为 `docker-compose.yml` 的文件,内容如下: ``` version: '3' services: zabbix-proxy: image: zabbix/zabbix-proxy5.0:latest container_name: zabbix-proxy environment: ZBX_HOSTNAME: zabbix-proxy ZBX_SERVER_HOST: zabbix-server ZBX_SERVER_PORT: "10051" ZBX_PROXYMODE: "0" ZBX_LOGTYPE: console ports: - "10051:10051" restart: always ``` 其中: - `image` 指定使用的镜像。 - `container_name` 指定容器的名称。 - `environment` 指定环境变量,包括 zabbix-proxy 的主机名、zabbix-server 的主机名或 IP 地址、监听端口、代理模式和日志输出方式。 - `ports` 将容器的 10051 端口映射到宿主机的 10051 端口。 - `restart` 指定容器停止后自动重启。 2. 在命令行中进入 `docker-compose.yml` 所在目录,运行以下命令启动容器: ``` docker-compose up -d ``` 这个命令将会启动一个名为 `zabbix-proxy` 的容器,并且将会输出容器的 ID。 3. 运行以下命令查看容器是否正常运行: ``` docker ps ``` 如果看到类似如下的输出,说明容器已经成功运行: ``` CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 3f0e931f2d35 zabbix/zabbix-proxy5.0:latest "/sbin/tini -- /usr/…" 10 seconds ago Up 8 seconds 0.0.0.0:10051->10051/tcp, 162/udp zabbix-proxy ``` 现在 zabbix-proxy5.0.31 已经成功运行在 Docker 容器中了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值