當前位置: 首頁>>代碼示例>>Golang>>正文


Golang redis.NewScript函數代碼示例

本文整理匯總了Golang中github.com/garyburd/redigo/redis.NewScript函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewScript函數的具體用法?Golang NewScript怎麽用?Golang NewScript使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了NewScript函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: StartKV

func StartKV(db *DB, pool *redis.Pool) {
	kvDB = db
	redisPool = pool

	c := redisPool.Get()
	defer c.Close()

	//cmdSetKV: key, value, expireTime
	cmdSetKV = redis.NewScript(3, SCRIPT_SET_KV)
	err := cmdSetKV.Load(c)
	PanicIfError(err)

	//cmdGetDel: key, value, expireTime
	cmdGetDel = redis.NewScript(1, SCRIPT_GETDEL)
	err = cmdGetDel.Load(c)
	PanicIfError(err)

	//cmdGetExpiredKV: key, value, expireTime
	cmdGetExpiredKV = redis.NewScript(1, SCRIPT_GET_EXPIRED_KV)
	err = cmdGetExpiredKV.Load(c)
	PanicIfError(err)

	//start save to db task
	go RepeatSingletonTask(redisPool, "kvSaveToDbTask", saveToDBTask)
	//go RepeatSingletonTask(redisPool, "hkvSaveToDB", hkvSaveToDB)

}
開發者ID:henyouqian,項目名稱:lwutil,代碼行數:27,代碼來源:kv_old.go

示例2: NewMutex

// Each lock will have a name which corresponds to a key in the Redis server.
// The mutex will also be initialized with a uuid. The mutex uuid
// can be used to extend the TTL for the lock.
func NewMutex(name string, ttl time.Duration) *Mutex {
	m := new(Mutex)
	m.Name = name
	m.Ttl = ttl
	m.Backoff = time.Second
	m.id = uuid()
	m.lock = redis.NewScript(1, luaLock)
	m.unlock = redis.NewScript(1, luaUnlock)
	return m
}
開發者ID:ryandotsmith,項目名稱:redisync,代碼行數:13,代碼來源:mutex.go

示例3: init

func init() {
	genericScript = strings.NewReplacer(
		"INSERTSUFFIX", insertSuffix,
		"DELETESUFFIX", deleteSuffix,
	).Replace(genericScript)

	insertScript = redis.NewScript(1, strings.NewReplacer(
		"REMSUFFIX", deleteSuffix, // Insert script does ZREM from deletes key
		"ADDSUFFIX", insertSuffix, // and ZADD to inserts key
	).Replace(genericScript))

	deleteScript = redis.NewScript(1, strings.NewReplacer(
		"REMSUFFIX", insertSuffix, // Delete script does ZREM from inserts key
		"ADDSUFFIX", deleteSuffix, // and ZADD to deletes key
	).Replace(genericScript))
}
開發者ID:nickstenning,項目名稱:roshi,代碼行數:16,代碼來源:cluster.go

示例4: ReadAllTasks

// ReadAllTasks load all unfinished task
func ReadAllTasks() []Task {
	c := Pool.Get()
	defer c.Close()
	var GetAllTasksLua = `
	local data = redis.call("LRANGE", "allTasks", "0", "-1")
	local ret = {}
  	for idx=1, #data do
  		ret[idx] = redis.call("HGETALL", "task:"..data[idx])
  	end
  	return ret
   `
	var tasks []Task
	script := redis.NewScript(0, GetAllTasksLua)
	values, err := redis.Values(script.Do(c))
	if err != nil {
		log.Println(err)
	}
	for i := range values {
		t := new(Task)
		redis.ScanStruct(values[i].([]interface{}), t)
		tasks = append(tasks, *t)
	}
	return tasks

}
開發者ID:evolsnow,項目名稱:robot,代碼行數:26,代碼來源:redis.go

示例5: Init

func (rli *RedisInput) Init(config interface{}) error {
	rli.conf = config.(*RedisInputConfig)

	var err error
	rli.conn, err = redis.Dial("tcp", rli.conf.Address)
	if err != nil {
		return fmt.Errorf("connecting to - %s", err.Error())
	}
	if _, err = rli.conn.Do("AUTH", rli.conf.Password); err != nil {
		rli.conn.Close()
		return fmt.Errorf("AUTH - %s", err.Error())
	}

	rli.batchlpop = redis.NewScript(1, `
          local i = tonumber(ARGV[1])
          local res = {}
          local length = redis.call('llen',KEYS[1])
          if length < i then i = length end
          while (i > 0) do
            local item = redis.call("lpop", KEYS[1])
            if (not item) then
              break
            end
            table.insert(res, item)
            i = i-1
          end
          return res
        `)

	return nil
}
開發者ID:swan-go,項目名稱:heka-redis,代碼行數:31,代碼來源:redis_input.go

示例6: getFreePort

func getFreePort(c *redis.Conn) int {
	// refreshOccupiedPorts(c)

	s := redis.NewScript(3, `
		redis.call("SDIFFSTORE", KEYS[3], KEYS[1], KEYS[2])
		redis.call("ZINTERSTORE", KEYS[3], 1, KEYS[3])
		local freePort = redis.call("ZRANGE", KEYS[3], 0, 0)[1]
		redis.call("SADD", KEYS[2], freePort)
		if freePort == nil then
			return 0
		else
			return freePort
		end
	`)

	r, e := redis.Int(s.Do(*c,
		getKey("ports", "possible"),
		getKey("ports", "occupied"),
		getKey("ports", "available")))
	if e != nil {
		log.Panic("Unable to fetch a free port: ", e)
	}

	return r
}
開發者ID:palpha,項目名稱:redis-landlord-srv,代碼行數:25,代碼來源:main.go

示例7: setTags

func setTags(prefix string, metrics string, tags []string) string {
	//TODO: call function
	client := clientFunction()
	defer client.Close()
	hashName := prefix + metrics + "\tTagHash"
	listName := prefix + metrics + "\tTagList"

	args := []string{}

	args = append(args, tags...)
	args = append(args, hashName)
	args = append(args, listName)

	scriptArgs := make([]interface{}, len(args))
	for i, v := range args {
		scriptArgs[i] = v
	}

	s := getLuaScript("setTag")
	script := redis.NewScript(len(tags), s)

	result, err := redis.String(script.Do(client, scriptArgs...))
	if err != nil {
		log.Println(err)
	}
	return result
}
開發者ID:zzzmanzzz,項目名稱:KsanaDB,代碼行數:27,代碼來源:RedisDAO.go

示例8: Set

func (this __red__model_ServiceType__field_SomeInt) Set(value int) {
	conn := this.__.(redis.Conn)

	{
		value := __red__to_string(value)

		_, err := redis.NewScript(0, `
				local rut = {}
do
	local sort = function (arr) table.sort(arr, function (a, b) return a[1] < b[1] end); return arr end
	rut.pack =  function (v) return cmsgpack.pack(sort(v)) end
	rut.hash =  function (v) return redis.sha1hex(rut.pack(v)) end
end

				local prim = ARGV[1]
				local value = ARGV[2]

				local baseKey = "red::obj::ServiceType::base::" .. prim

				local set = function ()
					redis.call("hset", baseKey, "SomeInt", value)
				end

				
				do
					 --> Unique index

						
							local _SomeInt = redis.call("hget", baseKey, "SomeInt") or "" 
						local oldKey = "red::idx::ServiceType::SomeInt::" .. rut.hash({ 
							{"SomeInt", _SomeInt}, 
						})
						local newKey = "red::idx::ServiceType::SomeInt::" .. rut.hash({ 
							{"SomeInt",  value  }, 
						})
						-- TODO: Ensure uniqueness
						-- TODO: What to do if key exists?
						if redis.call("exists", oldKey) then
							redis.call("set", newKey, prim)
							set()
							redis.call("del", oldKey)
						else
							redis.call("set", newKey, prim)
							set()
						end

					
				end
				

			`).Do(conn, this.__model.__prim, value, __red__to_string(time.Now().UTC().Unix()))
		if err != nil {
			panic(err)
		}

	}

}
開發者ID:themakers,項目名稱:red-go,代碼行數:58,代碼來源:red.gen.go

示例9: InitRedix

func InitRedix(addr string) {
	Redix = make([]redis.Conn, _Max)
	RedixMu = make([]*sync.Mutex, _Max)

	var err error
	for i := 0; i < _Max; i++ {
		Redix[i], err = redis.Dial("tcp", addr)
		if err != nil {
			panic(err)
		}
		RedixMu[i] = &sync.Mutex{}
		glog.Infof("RedisPool[%d] Init OK on %s\n", i, addr)
	}

	RedixAddr = addr
	netAddr, err := net.ResolveTCPAddr("tcp", addr)
	if err != nil {
		panic(err)
	}
	RedixAddrPool = []net.Addr{netAddr}

	ScriptSelectMobileId = redis.NewScript(1, _scriptSelectMobileId)
	ScriptSelectMobileId.Load(Redix[_SelectMobileId])
	ScriptOnline = redis.NewScript(2, _scriptOnline)
	ScriptOnline.Load(Redix[_SetUserOnline])
	ScriptOffline = redis.NewScript(2, _scriptOffline)
	ScriptOffline.Load(Redix[_SetUserOffline])

	if gCometType != msgs.CometUdp || gCometUdpSubBindingEvent {
		err = SubDeviceUsers()
		if err != nil {
			panic(err)
		}
	}
	err = SubModifiedPasswd()
	if err != nil {
		panic(err)
	}
	if gCometType != msgs.CometUdp || gCometPushUdp {
		err = SubCommonMsg()
		if err != nil {
			panic(err)
		}
	}
}
開發者ID:ljvblfz,項目名稱:slot-golang,代碼行數:45,代碼來源:redis.go

示例10: ExampleScript

func ExampleScript(c redis.Conn, reply interface{}, err error) {
	// Initialize a package-level variable with a script.
	var getScript = redis.NewScript(1, `return redis.call('get', KEYS[1])`)

	// In a function, use the script Do method to evaluate the script. The Do
	// method optimistically uses the EVALSHA command. If the script is not
	// loaded, then the Do method falls back to the EVAL command.
	reply, err = getScript.Do(c, "foo")
}
開發者ID:RomainVabre,項目名稱:origin,代碼行數:9,代碼來源:script_test.go

示例11: TestScript

func TestScript(t *testing.T) {
	c, err := redistest.Dial()
	if err != nil {
		t.Fatalf("error connection to database, %v", err)
	}
	defer c.Close()

	// To test fall back in Do, we make script unique by adding comment with current time.
	script := fmt.Sprintf("--%d\nreturn {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}", time.Now().UnixNano())
	s := redis.NewScript(2, script)
	reply := []interface{}{[]byte("key1"), []byte("key2"), []byte("arg1"), []byte("arg2")}

	v, err := s.Do(c, "key1", "key2", "arg1", "arg2")
	if err != nil {
		t.Errorf("s.Do(c, ...) returned %v", err)
	}

	if !reflect.DeepEqual(v, reply) {
		t.Errorf("s.Do(c, ..); = %v, want %v", v, reply)
	}

	err = s.Load(c)
	if err != nil {
		t.Errorf("s.Load(c) returned %v", err)
	}

	err = s.SendHash(c, "key1", "key2", "arg1", "arg2")
	if err != nil {
		t.Errorf("s.SendHash(c, ...) returned %v", err)
	}

	err = c.Flush()
	if err != nil {
		t.Errorf("c.Flush() returned %v", err)
	}

	v, err = c.Receive()
	if !reflect.DeepEqual(v, reply) {
		t.Errorf("s.SendHash(c, ..); c.Receive() = %v, want %v", v, reply)
	}

	err = s.Send(c, "key1", "key2", "arg1", "arg2")
	if err != nil {
		t.Errorf("s.Send(c, ...) returned %v", err)
	}

	err = c.Flush()
	if err != nil {
		t.Errorf("c.Flush() returned %v", err)
	}

	v, err = c.Receive()
	if !reflect.DeepEqual(v, reply) {
		t.Errorf("s.Send(c, ..); c.Receive() = %v, want %v", v, reply)
	}

}
開發者ID:RomainVabre,項目名稱:origin,代碼行數:57,代碼來源:script_test.go

示例12: LPOPRPUSH

func LPOPRPUSH(cnx redis.Conn) *redis.Script {
	lmu.Lock()
	defer lmu.Unlock()

	if lpoprpush == nil {
		lpoprpush = redis.NewScript(2, lpoprpushSrc)
	}

	return lpoprpush
}
開發者ID:wulffeld,項目名稱:redutil,代碼行數:10,代碼來源:scripts.go

示例13: NewProvider

func (c RedisProviderConfig) NewProvider() (Provider, error) {
	p := &RedisProvider{
		BaseProvider: BaseProvider{c},
	}

	p.pool = redis.Pool{
		MaxIdle:     10,
		IdleTimeout: 240 * time.Second,
		Dial: func() (redis.Conn, error) {
			conn, err := redis.Dial("tcp", c.Host+":"+strconv.Itoa(c.Port))
			if err != nil {
				return nil, err
			}
			if len(c.Password) > 0 {
				if _, err := conn.Do("AUTH", c.Password); err != nil {
					conn.Close()
					return nil, err
				}
			}

			if _, err := conn.Do("SELECT", c.Database); err != nil {
				conn.Close()
				return nil, err
			}
			return conn, err
		},
		TestOnBorrow: func(c redis.Conn, t time.Time) error {
			_, err := c.Do("PING")
			return err
		},
	}
	p.countScript = redis.NewScript(0, `return #redis.call('keys', '::till:value:*')`)
	p.randomValueKeyScript = redis.NewScript(0, `
		local keys = redis.call('keys', '::till:value:*')
if #keys > 0 then
    return keys[1]
else
    return nil
end
	`)
	return p, nil
}
開發者ID:psobot,項目名稱:till,代碼行數:42,代碼來源:redis.go

示例14: CreateMemo

// CreateMemo saves a memo
func CreateMemo(user, when, memo string) {
	c := Pool.Get()
	defer c.Close()
	var setMemoLua = `
	local id = redis.call("INCR", "memoIncrId")
	redis.call("RPUSH", KEYS[1]..":memos", id)
	redis.call("HMSET", "memo:"..id, "time", KEYS[2], "content", KEYS[3])
	`
	script := redis.NewScript(3, setMemoLua)
	script.Do(c, user, when, memo)
}
開發者ID:evolsnow,項目名稱:robot,代碼行數:12,代碼來源:redis.go

示例15: DeleteMemo

// DeleteMemo deletes a memo
func DeleteMemo(user string, index int) {
	c := Pool.Get()
	defer c.Close()
	var deleteMemoLua = `
	local id = redis.call("LINDEX", KEYS[1]..":memos", KEYS[2])
	redis.call("LREM", KEYS[1]..":memos", 1, id)
	redis.call("DEL", "memo:"..id)
	`
	script := redis.NewScript(2, deleteMemoLua)
	script.Do(c, user, index)
}
開發者ID:evolsnow,項目名稱:robot,代碼行數:12,代碼來源:redis.go


注:本文中的github.com/garyburd/redigo/redis.NewScript函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。