Ok, nevermind. It was a PHP error. Putting $client->errorno() inside the string, it was trying to access $client->errorno, which is indeed a protected attribute.
The error is “Bin name longer than 14 chars”. Indeed, I use a Facebook ID as a key, and Facebook IDs have 16 characters, and sometimes more.
This is a real problem, because this id is the only identifier I have for my users… and I can’t truncate it without risking duplicates…
What can I do to solve this?
Is there a way to change this limit?
I’m not sure why you’d use the Facebook ID as the key, seems like it should be the value, and the bin name something like ‘fbid’, no? It doesn’t make sense to me, I wonder if you could explain the thinking behind it.
Be aware that there’s a limit of 32k unique bin names in a namespace. See the FAQ.
I took a look at the FAQ about limits… I’m not sure how I am going to scale this to potential millions of users…
I guess I can just split the key into several parts, like this:
Then I would have 14 character key names in each set, 1000 sets per namespace, and 10 namespaces…
The total number of users would be limited to 327 670 000 users, which is more than enough.
But it’s a very fragile structure… what if Facebook changes their ids for longer ones? (it wouldn’t be the first time)
Your example makes it look like those FB IDs should be the primary key for a set named ‘facebook’ (or something of that sort). The primary key can be of any length since it actually gets hashed into a 20 byte digest used by the client and server nodes to locate the record.
I thought the bin name and the primary was the same thing… I’m confused.
If I take the example from the Quick Guide:
$key = $db->initKey("infosphere", "characters", 3);
$bins = ["name" => "Bender", "Occupation" => "Bender", "age" => 1055];
// store the key data with the record, rather than just its digest
$option = [Aerospike::OPT_POLICY_KEY => Aerospike::POLICY_KEY_SEND];
$db->put($key, $bins, 0, $option);
I see a namespace, a set, a primary key name for the bins, and bins containing keys->values.
I looked into the API reference, and the $pk parameter for the initKey method is where I put my Facebook IDs.
So if you say thay $pk can have any length… it shouldn’t raise an error…
Edit: nevermind… “last_reward_time” has 16 characters… that’s probably what’s raising the error :facepalm: