*** kei-ichi has quit IRC | 00:02 | |
*** kei-ichi has joined #openstack-swift | 00:02 | |
*** germs has quit IRC | 00:15 | |
*** germs has joined #openstack-swift | 00:17 | |
*** gyee has quit IRC | 00:20 | |
*** pdardeau has joined #openstack-swift | 00:29 | |
openstackgerrit | Tim Burke proposed openstack/swift feature/deep: Fix up probetests check on feature/deep https://review.openstack.org/550291 | 00:30 |
---|---|---|
*** germs has quit IRC | 00:32 | |
*** tovin07_ has joined #openstack-swift | 00:36 | |
*** germs has joined #openstack-swift | 00:42 | |
*** germs has quit IRC | 00:42 | |
*** germs has joined #openstack-swift | 00:42 | |
*** germs has quit IRC | 00:48 | |
*** germs has joined #openstack-swift | 00:49 | |
*** germs has quit IRC | 00:53 | |
*** mingyu has quit IRC | 00:57 | |
*** gerardgine has quit IRC | 01:06 | |
*** NM has joined #openstack-swift | 01:12 | |
*** itlinux has quit IRC | 01:12 | |
*** NM has quit IRC | 01:18 | |
*** gerardgine has joined #openstack-swift | 01:25 | |
*** gerardgine has quit IRC | 02:05 | |
*** gerardgine has joined #openstack-swift | 02:20 | |
*** germs has joined #openstack-swift | 02:20 | |
*** germs has quit IRC | 02:20 | |
*** germs has joined #openstack-swift | 02:20 | |
*** germs has quit IRC | 02:43 | |
*** germs has joined #openstack-swift | 02:43 | |
*** germs has quit IRC | 02:43 | |
*** germs has joined #openstack-swift | 02:43 | |
openstackgerrit | Tim Burke proposed openstack/swift feature/deep: Fix up probetests check on feature/deep https://review.openstack.org/550291 | 02:45 |
*** gerardgine has quit IRC | 02:47 | |
*** psachin has joined #openstack-swift | 02:47 | |
*** germs has quit IRC | 02:48 | |
*** psachin has quit IRC | 02:59 | |
*** psachin has joined #openstack-swift | 03:03 | |
*** psachin has quit IRC | 03:05 | |
*** gerardgine has joined #openstack-swift | 03:07 | |
*** psachin has joined #openstack-swift | 03:08 | |
*** psachin has quit IRC | 03:17 | |
*** psachin has joined #openstack-swift | 03:35 | |
*** cshastri has joined #openstack-swift | 03:36 | |
*** kei_yama has quit IRC | 03:47 | |
*** gkadam has joined #openstack-swift | 03:59 | |
*** kei_yama has joined #openstack-swift | 04:02 | |
*** gerardgine has quit IRC | 04:03 | |
*** kei_yama has quit IRC | 04:10 | |
*** kei_yama has joined #openstack-swift | 04:12 | |
*** ianychoi_ has joined #openstack-swift | 04:12 | |
*** mlanner has quit IRC | 04:14 | |
*** kei_yama_ has joined #openstack-swift | 04:15 | |
*** mlanner has joined #openstack-swift | 04:15 | |
*** ianychoi has quit IRC | 04:15 | |
*** kei_yama has quit IRC | 04:17 | |
*** thurloat has quit IRC | 04:17 | |
*** kei_yama_ has quit IRC | 04:21 | |
*** links has joined #openstack-swift | 04:22 | |
*** kei_yama has joined #openstack-swift | 04:30 | |
*** sjmurdoch128 has joined #openstack-swift | 04:44 | |
*** sjmurdoch128 has quit IRC | 04:46 | |
*** linuxdaemonah has joined #openstack-swift | 05:02 | |
*** arunman has joined #openstack-swift | 05:24 | |
*** arunmani_ has joined #openstack-swift | 05:29 | |
*** arunman has quit IRC | 05:30 | |
*** thurloat has joined #openstack-swift | 05:36 | |
*** ianychoi__ has joined #openstack-swift | 06:43 | |
*** ianychoi_ has quit IRC | 06:46 | |
kota_ | hello world | 06:48 |
*** gkadam has quit IRC | 06:50 | |
*** ianychoi__ is now known as ianychoi | 06:51 | |
*** pcaruana has joined #openstack-swift | 07:04 | |
*** tovin07 has joined #openstack-swift | 07:28 | |
*** armaan has quit IRC | 07:36 | |
*** armaan has joined #openstack-swift | 07:36 | |
*** gkadam has joined #openstack-swift | 07:40 | |
*** hseipp has joined #openstack-swift | 07:43 | |
*** tesseract has joined #openstack-swift | 08:14 | |
*** geaaru has joined #openstack-swift | 08:30 | |
*** hoonetorg has quit IRC | 08:30 | |
*** mingyu has joined #openstack-swift | 08:30 | |
*** hoonetorg has joined #openstack-swift | 08:43 | |
*** kei_yama has quit IRC | 08:47 | |
*** hseipp has quit IRC | 09:03 | |
*** hseipp has joined #openstack-swift | 09:14 | |
*** hseipp has quit IRC | 09:31 | |
*** hseipp has joined #openstack-swift | 09:31 | |
*** hseipp has quit IRC | 09:32 | |
openstackgerrit | Kota Tsuyuzaki proposed openstack/swift feature/s3api: Update S3api Docs https://review.openstack.org/552853 | 09:33 |
openstackgerrit | Kota Tsuyuzaki proposed openstack/swift feature/s3api: Cleanup swift/common/middleware/s3api/test dir https://review.openstack.org/552854 | 09:33 |
openstackgerrit | Alistair Coles proposed openstack/swift feature/deep: Fix up probetests check on feature/deep https://review.openstack.org/550291 | 09:37 |
*** hseipp has joined #openstack-swift | 09:40 | |
*** tovin07_ has quit IRC | 10:06 | |
*** rcernin has quit IRC | 10:13 | |
*** mingyu has quit IRC | 10:18 | |
openstackgerrit | Alexandre Lécuyer proposed openstack/swift master: Add optional parameters to common/utils fallocate() https://review.openstack.org/548034 | 10:25 |
root_743 | hello, is there any way to rebuild the rings of my swift single controller cluster? all of the images on swift got moved to a "quarantined" directory in my filesystem because (and I think this was the issue), swift.conf got modified by adding swift_hash_path_preffix (originally we only had swift_hash_path_suffix and now the configuration was reverted back) but the files are still in quarantined | 10:31 |
*** mingyu has joined #openstack-swift | 10:42 | |
*** cshastri has quit IRC | 10:43 | |
openstackgerrit | Kota Tsuyuzaki proposed openstack/swift feature/s3api: Avoid global CONF instance https://review.openstack.org/551273 | 10:48 |
*** ianychoi has quit IRC | 11:07 | |
*** ianychoi has joined #openstack-swift | 11:13 | |
kei-ichi | I'm now sending this patch and get one comment from infra team. https://review.openstack.org/#/c/552282/ | 11:15 |
patchbot | patch 552282 - openstack-infra/project-config - Add slogging projects | 11:15 |
kei-ichi | Infra team propose me how to use swift IRC chanel to inform slogging event. | 11:15 |
kei-ichi | So let me confirm one thing. Can I use swift IRC channel from slogging to inform each events ? (like "patchset-created" , "change-merged" , "x-vrif-minus-2") | 11:15 |
kei-ichi | Now I'm fixing unittest of sloggin so that my patch can pass zuul check. | 11:16 |
kei-ichi | I made mistake in preparation for this so once remove notmyname mattoliverau kota_ from review of this. (To avoid many number of mail wiil be sent to you ...) | 11:16 |
kei-ichi | If I can pass zuul check, let me add everyone as reviewer again! | 11:16 |
*** HW-Peter has quit IRC | 11:22 | |
*** armaan has quit IRC | 11:25 | |
acoles | kei-chi: does #openstack-slogging IRC channel already exist? if it does exist then IMHO that would be the best place for gerrit to announce changes to the slogging project. If it does not exist then the question is perhaps 'does slogging need a separate IRC channel?' and the best way to get consensus on that question would be to add it as a topic for today's swift meeting. You can edit the wiki https://wiki.openstack.org/ | 11:27 |
acoles | wiki/Meetings/Swift | 11:27 |
acoles | https://wiki.openstack.org/wiki/Meetings/Swift | 11:27 |
*** arunmani_ has quit IRC | 11:37 | |
openstackgerrit | Alistair Coles proposed openstack/swift feature/deep: Fix up probetests check on feature/deep https://review.openstack.org/550291 | 11:42 |
kei-ichi | acoles Thank you! | 11:42 |
kei-ichi | I didn't prepare #openstack-slogging yet. But firstly try to create that. After sending patch, infra team propose me about sharing IRC channel so I'd like to confirm to swift team first. | 11:45 |
kei-ichi | I also think it is better to add this topic at IRC. I'll edit above page o/ | 11:45 |
*** armaan has joined #openstack-swift | 11:53 | |
*** armaan has quit IRC | 12:05 | |
*** armaan has joined #openstack-swift | 12:06 | |
*** kei-ichi has quit IRC | 12:08 | |
*** kei-ichi has joined #openstack-swift | 12:09 | |
*** armaan has quit IRC | 12:10 | |
*** zhongjun has quit IRC | 12:14 | |
*** armaan has joined #openstack-swift | 12:24 | |
*** armaan has quit IRC | 12:24 | |
*** armaan_ has joined #openstack-swift | 12:29 | |
*** armaan_ has quit IRC | 12:53 | |
*** armaan has joined #openstack-swift | 12:53 | |
openstackgerrit | Alexandre Lécuyer proposed openstack/swift master: Change object_audit_location_generator() to yield for a single policy. https://review.openstack.org/548589 | 13:15 |
*** saint_ has joined #openstack-swift | 13:28 | |
*** arunman has joined #openstack-swift | 13:34 | |
*** zhongjun has joined #openstack-swift | 13:53 | |
*** arunman has quit IRC | 14:05 | |
acoles | timburke: probe tests passed at last https://review.openstack.org/550291 :) | 14:14 |
patchbot | patch 550291 - swift (feature/deep) - Fix up probetests check on feature/deep | 14:14 |
*** ukaynar has joined #openstack-swift | 14:26 | |
*** psachin has quit IRC | 14:30 | |
*** germs has joined #openstack-swift | 14:35 | |
*** germs has quit IRC | 14:35 | |
*** germs has joined #openstack-swift | 14:35 | |
*** wes_dillingham has joined #openstack-swift | 14:39 | |
*** mvk has quit IRC | 14:40 | |
*** mrjk__ has quit IRC | 14:44 | |
openstackgerrit | Alistair Coles proposed openstack/swift feature/deep: Make concatentaion of shard listings more robust https://review.openstack.org/552913 | 14:45 |
*** zaitcev__ has joined #openstack-swift | 14:45 | |
*** ChanServ sets mode: +v zaitcev__ | 14:45 | |
*** mrjk has joined #openstack-swift | 14:46 | |
*** zaitcev_ has quit IRC | 14:48 | |
openstackgerrit | Alistair Coles proposed openstack/swift feature/deep: Fix up probetests check on feature/deep https://review.openstack.org/550291 | 14:51 |
openstackgerrit | Alistair Coles proposed openstack/swift feature/deep: Pass bind_ip to whataremyips https://review.openstack.org/552916 | 14:51 |
*** germs has quit IRC | 14:55 | |
*** mvk has joined #openstack-swift | 14:55 | |
*** itlinux has joined #openstack-swift | 15:12 | |
*** germs has joined #openstack-swift | 15:13 | |
*** germs has quit IRC | 15:14 | |
*** germs has joined #openstack-swift | 15:15 | |
*** germs has quit IRC | 15:15 | |
*** germs has joined #openstack-swift | 15:15 | |
*** links has quit IRC | 15:18 | |
*** wes_dillingham has quit IRC | 15:22 | |
*** wes_dillingham has joined #openstack-swift | 15:33 | |
*** ukaynar has quit IRC | 15:33 | |
*** SkyRocknRoll has joined #openstack-swift | 15:48 | |
timburke | acoles: w00t! thanks for running that down... | 15:59 |
acoles | timburke: the logs were quite useful so thanks for those ! | 15:59 |
*** gerardgine has joined #openstack-swift | 15:59 | |
timburke | acoles: did we ever get a good state-machine diagram going? between p 551356 and a growing thought that we may want a new state between FOUND and CREATED (so all replicas could look for shards before a leader or external actor decides on a set to use -- COMMITTED, maybe?) the number of states is getting fairly large... | 16:08 |
patchbot | https://review.openstack.org/#/c/551356/ - swift (feature/deep) - Use state rather than subtlety to make shards of s... | 16:08 |
*** ukaynar has joined #openstack-swift | 16:10 | |
acoles | timburke: re state machine diagram - no, re maybe needing another state - agree | 16:10 |
*** ukaynar has quit IRC | 16:11 | |
acoles | although IDK whether we'd deliberately allow all replicas to scan for shard ranges - we also had a though for the 'leader'/external actor to prescribe the number of ranges to find | 16:12 |
*** ukaynar has joined #openstack-swift | 16:12 | |
acoles | Although, I guess all replicas could find potentially differing numbers of ranges and leader selects best set??? | 16:13 |
timburke | that's along the lines of what i was thinking. and then you can have the find_shard_ranges script be able to serve from cache instead of taking... tens of minutes? hours? to run | 16:19 |
acoles | timburke: yes. I do like the idea that an external actor just needs to transition states, approve ranges and leave real work to swift processes | 16:25 |
acoles | timburke: and surely there's a tequila per shard range state once we're done? ;-) | 16:25 |
acoles | timburke: so were you thinking we'd just have a sharder daemon go ahead and scan for ranges on any sizeable container, then drop some notification and wait for external actor to come along and approve some ranges? | 16:37 |
acoles | hmmm, the ranges might get stale | 16:38 |
timburke | maybe? i hadn't thought it through entirely yet (and might not be in a good state to do so right now) | 16:38 |
acoles | :) | 16:38 |
timburke | yeah, we have to worry about stale ranges. i'm thinking give them a lifetime around one reclaim_age? | 16:39 |
timburke | otoh, maybe this is something better kicked out until later... idk | 16:41 |
acoles | or if actor finds ranges and can infer they may be state, actor deletes them and sharder scans again | 16:41 |
acoles | stale* | 16:41 |
acoles | feature/deep probe tests into gate jobs :D | 16:44 |
openstackgerrit | Alistair Coles proposed openstack/swift feature/deep: Make concatenation of shard listings more robust https://review.openstack.org/552913 | 16:51 |
openstackgerrit | Alexandre Lécuyer proposed openstack/swift master: Change object_audit_location_generator() to yield for a single policy. https://review.openstack.org/548589 | 16:57 |
*** armaan has quit IRC | 16:59 | |
*** SkyRocknRoll has quit IRC | 17:00 | |
*** gerardgine has quit IRC | 17:00 | |
*** gkadam has quit IRC | 17:05 | |
*** armaan has joined #openstack-swift | 17:13 | |
*** gerardgine has joined #openstack-swift | 17:14 | |
*** pcaruana has quit IRC | 17:18 | |
*** hseipp has quit IRC | 17:25 | |
*** gerardgine has quit IRC | 17:50 | |
*** itlinux has quit IRC | 17:50 | |
*** gerardgine has joined #openstack-swift | 17:50 | |
*** links has joined #openstack-swift | 17:57 | |
*** itlinux has joined #openstack-swift | 17:58 | |
*** gyee has joined #openstack-swift | 18:05 | |
*** mrjk has quit IRC | 18:08 | |
*** mrjk has joined #openstack-swift | 18:09 | |
*** geaaru has quit IRC | 18:14 | |
*** hseipp has joined #openstack-swift | 18:16 | |
*** hseipp has quit IRC | 18:36 | |
*** mvk has quit IRC | 18:41 | |
openstackgerrit | Merged openstack/swift feature/deep: Pass bind_ip to whataremyips https://review.openstack.org/552916 | 18:50 |
*** itlinux has quit IRC | 18:57 | |
*** itlinux_ has joined #openstack-swift | 18:57 | |
*** mvk has joined #openstack-swift | 19:09 | |
*** tesseract has quit IRC | 19:20 | |
openstackgerrit | Merged openstack/swift feature/deep: Fix up probetests check on feature/deep https://review.openstack.org/550291 | 19:31 |
*** links has quit IRC | 19:34 | |
*** itlinux_ has quit IRC | 19:40 | |
timburke | acoles: i wonder if we could get away from having db_state in favor of looking at the state recorded in own_shard_range... | 19:47 |
notmyname | reminder, especially for those in the US. the meeting is at 2100UTC. that's in an hour. not now | 19:50 |
*** itlinux has joined #openstack-swift | 19:53 | |
tdasilva | oh | 20:00 |
tdasilva | that's right...thanks for the reminder | 20:00 |
acoles | timburke: maybe but there's times when the two are not the same...for example, a shard range moves to sharded once any of the replicas has completed cleaving, whereas other replica's db_state may still be sharding. so there's sometimes a useful distinction. But every now and again I have exactly the thought you had :) | 20:06 |
* acoles back later for mtg | 20:06 | |
spotz | Anyone about to answer a quick CLI question? | 20:11 |
*** Supun has joined #openstack-swift | 20:12 | |
*** silor has joined #openstack-swift | 20:15 | |
*** geaaru has joined #openstack-swift | 20:20 | |
openstackgerrit | Merged openstack/swift master: Add handoffs-only mode to DB replicators. https://review.openstack.org/545497 | 20:36 |
notmyname | spotz: don't ask to ask. just ask :-) | 20:36 |
*** silor has quit IRC | 20:36 | |
spotz | notmyname: I tried to be polite:) But trying to expire an object with swift post and it returns the help | 20:37 |
spotz | so could be a bug, removed functionaility or.... | 20:37 |
clayg | timburke: kota_ : any takers? http://lists.openstack.org/pipermail/openstack/2018-March/046188.html | 20:37 |
*** m_kazuhiro has joined #openstack-swift | 20:37 | |
spotz | notmyname: And actually if I cut and paste the -H content-length from the help it returns the help as well | 20:38 |
notmyname | spotz: can you pastebin what you're doing (redact any passwords, etc) | 20:38 |
spotz | notmyname: Sure | 20:38 |
spotz | notmyname: https://pastebin.com/ZSDsXzqQ | 20:39 |
*** Supun has quit IRC | 20:39 | |
spotz | notmyname: packstack stable/pike if that helps any | 20:40 |
notmyname | spotz: seems to be the --os-project-name that's getting in the way. not sure why, yet | 20:43 |
*** wes_dillingham has quit IRC | 20:44 | |
spotz | notmyname: Interesting because it worked fine for both read and write ACLs | 20:44 |
spotz | as well as creating the container and uploading the object | 20:44 |
torgomatic | also, once you get past that, you're going to want "X-Delete-After: 3600", not -At. | 20:50 |
timburke | clayg: yeah, seems right. the trick is that you don't want any single host to have more than m frags; ceil((k+m)/m) hosts should ensure that | 20:50 |
timburke | the ceil is important, tho -- 8+2 worked out nicely, but 7+3 is a little more awkward; (k+m)/m gets you 3.33 -- if you round nearest, you get three, so a layout like 4-4-3 | 20:51 |
timburke | and a single host failure has a 2/3 chance of causing availability issues | 20:51 |
spotz | torgomatic: Yeah that was in my original, I've been trying different combos trying to figure out what was going on | 20:51 |
timburke | ceil forces you to four, so 3-3-2-2 and you can lose one but still reconstruct (assuming your dispersion is good! not necessarily the case, depending on relative drive weights) | 20:52 |
torgomatic | spotz: just spitballing here since swiftclient is not my area of expertise, but have you tried "swift --os-project-name dev post ..." ? | 20:54 |
*** gerardgine has quit IRC | 20:54 | |
notmyname | yes! that's it | 20:54 |
spotz | torgomatic: let me give it a shot, but not sure why it would only effect headers | 20:54 |
*** mathiasb has joined #openstack-swift | 20:54 | |
torgomatic | I couldn't tell you, but if you're getting the help message, something's confused the argument parser | 20:55 |
notmyname | spotz: turns out the options parsing code isn't that straightforward. and the commands (eg "post") are sortof compartmentalized and almost implemented as plugins (not really, but sortof). beasically, this means that options order is important and "post" doesn't know about that auth thing, but the "swift" command does | 20:55 |
spotz | torgomatic notmyname - moving it up between swift and posr says no such command | 20:56 |
notmyname | mine works | 20:56 |
notmyname | swift --os-project-name dev post resources files/dev.png --header "X-Delete-At:3600" | 20:56 |
notmyname | Object POST failed: http://192.168.56.2:8080/v1/AUTH_test/resources/files/dev.png 400 Bad Request X-Delete-At in past | 20:56 |
notmyname | Failed Transaction ID: txbec23d214a6249c88ff25-005aa98c0dsaio | 20:56 |
kota_ | good morning | 20:56 |
notmyname | spotz: I'm using swiftclient 3.4.0 | 20:57 |
timburke | crap, i thought when i moved it to argparse i made the arg-ordering problem go away... | 20:57 |
spotz | notmyname: Ha when I cut and pasted yours in it worked:) | 20:57 |
spotz | you used --header I used -H | 20:57 |
notmyname | ah | 20:58 |
notmyname | normally I use curl ;-) | 20:58 |
spotz | should be the same but yeah | 20:58 |
timburke | that just raises more questions :-/ hmm... | 20:58 |
spotz | notmyname: I'm working on a lesson on ACLs from the CLI. I find lots of issues when I make new lessons:) | 20:58 |
kota_ | clayg: let me check the context of the e-mail thread for the ec question... | 20:59 |
notmyname | ah yes. I've been asked about that before. it's a tricky topic | 20:59 |
torgomatic | at some point it's just easier to cat > /dev/tcp/192.168.56.2/8080 ;) | 20:59 |
notmyname | swift team meeting time in #openstack-meeting | 20:59 |
*** zaitcev__ is now known as zaitcev | 20:59 | |
spotz | notmyname: Let me know if you want me to bug it. Thanks for the help and happy meeting:) | 20:59 |
notmyname | spotz: maybe the -H/--header. not the other one | 21:00 |
spotz | notmyname: will do | 21:00 |
notmyname | thanks | 21:01 |
*** wes_dillingham has joined #openstack-swift | 21:03 | |
*** rcernin has joined #openstack-swift | 21:08 | |
*** gerardgine has joined #openstack-swift | 21:15 | |
notmyname | mattoliverau: in the meeting you just got volunteered to rereview https://review.openstack.org/#/c/551956/ | 21:21 |
patchbot | patch 551956 - python-swiftclient - Add force auth retry mode in swiftclient | 21:21 |
clayg | great meeting | 21:39 |
*** acoles has left #openstack-swift | 21:40 | |
*** itlinux has quit IRC | 21:40 | |
*** acoles has joined #openstack-swift | 21:40 | |
*** ChanServ sets mode: +v acoles | 21:40 | |
* kota_ is trying to find my breakfast | 21:40 | |
acoles | timburke: hehe I was about to say thanks again to tdasilva for probe tests in zuul | 21:40 |
*** m_kazuhiro has quit IRC | 21:40 | |
notmyname | those probe tests are great! | 21:40 |
acoles | notmyname: ...until they fail ;) | 21:41 |
timburke | well that's why we made it non-voting :P | 21:49 |
*** dmorita has joined #openstack-swift | 21:50 | |
*** dmorita has quit IRC | 21:51 | |
*** dmorita has joined #openstack-swift | 21:51 | |
*** dmorita has quit IRC | 21:52 | |
*** geaaru has quit IRC | 22:16 | |
*** dmorita has joined #openstack-swift | 22:22 | |
*** dmorita has quit IRC | 22:24 | |
*** dmorita has joined #openstack-swift | 22:24 | |
*** ukaynar has quit IRC | 22:26 | |
*** dmorita has quit IRC | 22:29 | |
*** wes_dillingham has quit IRC | 22:38 | |
*** dmorita has joined #openstack-swift | 22:39 | |
*** dmorita has quit IRC | 22:40 | |
*** armaan has quit IRC | 23:11 | |
openstackgerrit | Samuel Merritt proposed openstack/swift master: Remove object replicator's lockup detector/mitigator. https://review.openstack.org/552659 | 23:15 |
*** kei_yama has joined #openstack-swift | 23:21 | |
*** NM has joined #openstack-swift | 23:22 | |
*** NM has quit IRC | 23:29 | |
*** itlinux has joined #openstack-swift | 23:47 | |
*** NM has joined #openstack-swift | 23:49 | |
mattoliverau | Sure, sorry, been hit with a gastro bug, /me feeling much better but now Bec has it. So sitting in a hospital with a drip to rehydrate her (just for safely re: baby)... Fun times :( | 23:56 |
Generated by irclog2html.py 2.15.3 by Marius Gedminas - find it at mg.pov.lt!